:target {
  scroll-margin-top: calc(var(--header_h) * -1);
}

:where(*) {
  box-sizing: border-box;
}

.en {
  font-family: "minion-pro", serif;
}

body {
  overflow: auto;
  height: auto !important;
  background-color: #fff;
}

.timerHidden {
  display: none;
}

.timerVisible {
  display: block;
}

#headBar {
  background-color: #1b63b6;
  padding: 3.125vw;
  color: #fff;
  font-size: 3.75vw;
  text-align: center;
}
@media screen and (min-width: 769px) {
  #headBar {
    padding: 1.2244897959vw;
    font-size: 1.2755102041vw;
  }
}
#headBar a {
  color: currentColor;
}

header {
  position: sticky;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
}
header img {
  height: auto;
  vertical-align: middle;
}

.ochugen section img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}
.ochugen_header {
  display: flex;
  justify-content: space-between;
  position: relative;
}
.ochugen_header_logo {
  position: relative;
  z-index: 12;
}
.ochugen_header_logo a {
  display: block;
  padding: 3.125vw 3.75vw;
}
@media screen and (min-width: 769px) {
  .ochugen_header_logo a {
    padding: 1.9387755102vw 2.5510204082vw;
  }
}
.ochugen_header_logo img {
  width: 37.5vw;
}
@media screen and (min-width: 769px) {
  .ochugen_header_logo img {
    width: max(150px, 10.4591836735vw);
  }
}
@media screen and (max-width: 768px) {
  .ochugen_header.active .ochugen_menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
}
.ochugen_header.active .ochugen_navbtn span:nth-child(1) {
  transform: translateY(-5px) rotate(-28deg);
}
.ochugen_header.active .ochugen_navbtn span:nth-child(2) {
  transform: translateY(6px) rotate(28deg);
}
.ochugen_navbtn {
  position: relative;
  z-index: 12;
  -webkit-appearance: none;
  appearance: none;
  background-color: transparent;
  border: none;
  width: 10.625vw;
  padding: 5.625vw 5vw;
  box-sizing: content-box;
  display: flex;
  flex-direction: column;
}
.ochugen_navbtn span {
  width: 100%;
  height: 1px;
  background-color: #1b63b6;
  transition: transform 0.3s;
  transform-origin: center right;
}
.ochugen_navbtn span:nth-child(2) {
  margin-top: 1.5625vw;
}
@media screen and (min-width: 769px) {
  .ochugen_navbtn {
    display: none !important;
  }
}
.ochugen_menu {
  overscroll-behavior-y: contain;
}
@media screen and (max-width: 768px) {
  .ochugen_menu {
    display: flex;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s, visibility 0.3s;
    background-color: #fff;
    position: fixed;
    top: 0;
    width: 100%;
    height: 100vh;
    height: 100dvh;
    z-index: 11;
    align-items: center;
    justify-content: center;
    flex-direction: column;
  }
}
@media screen and (min-width: 769px) {
  .ochugen_menu {
    writing-mode: vertical-rl;
    text-orientation: mixed;
    padding-right: 2.0408163265vw;
  }
}
.ochugen_menu a {
  font-family: "minion-pro", serif;
  line-height: 1;
  display: block;
  color: #1b63b6;
}
@media screen and (max-width: 768px) {
  .ochugen_menu a {
    font-size: 6.25vw;
    padding: 4.6875vw 0;
    font-weight: 600;
  }
}
@media screen and (min-width: 769px) {
  .ochugen_menu a {
    font-size: max(12px, 1.2244897959vw);
    padding: 1.2755102041vw 0.8163265306vw;
  }
}
@media screen and (max-width: 768px) {
  .ochugen_menu a.active span:before {
    width: calc(100% + 6.25vw);
  }
}
@media screen and (min-width: 769px) {
  .ochugen_menu a.active span:before {
    height: calc(100% + 1.0204081633vw);
  }
}
.ochugen_menu a span {
  position: relative;
}
.ochugen_menu a span:before {
  content: "";
  background-color: #1b63b6;
  position: absolute;
}
@media screen and (max-width: 768px) {
  .ochugen_menu a span:before {
    width: 0;
    height: 1px;
    top: 50%;
    left: -3.125vw;
    transition: width 0.2s;
  }
}
@media screen and (min-width: 769px) {
  .ochugen_menu a span:before {
    width: 1.5px;
    height: 0;
    top: -0.5102040816vw;
    left: 50%;
    transition: height 0.2s;
  }
}
.ochugen_kv {
  height: calc(100vh - var(--info_h));
  margin-top: calc(var(--header_h) * -1);
  overflow: hidden;
}
.ochugen_kv-main, .ochugen_kv-slider,
.ochugen_kv .slick-list,
.ochugen_kv .slick-track {
  height: 100%;
}
.ochugen_kv-slider {
  pointer-events: none !important;
}
.ochugen_kv-item {
  position: relative;
  height: 100%;
  pointer-events: none;
}
.ochugen_kv-item.slick-active .ochugen_kv-link a svg .line-move {
  animation: circle linear 5.8s;
}
.ochugen_kv-item.on-active .ochugen_kv-pacage,
.ochugen_kv-item.on-active .ochugen_kv-detail {
  transform: translateY(10%);
  opacity: 0;
}
.ochugen_kv-item.on-out .ochugen_kv-keyword_txt {
  transform: translateY(-100%);
}
.ochugen_kv-item.on-out .ochugen_kv-pacage,
.ochugen_kv-item.on-out .ochugen_kv-detail {
  transform: translateY(-40%);
  opacity: 0;
}
@media screen and (min-width: 769px) {
  .ochugen_kv-item:nth-child(3) .ochugen_kv-pacage img {
    width: 43.2653061224vw;
  }
}
.ochugen_kv-img {
  height: 100%;
}
.ochugen_kv-img img {
  width: 100%;
  height: 100% !important;
  object-fit: cover;
}
.ochugen_kv-keyword {
  position: absolute;
  top: 97vw;
  left: 0;
  overflow: hidden;
  height: 21.875vw;
}
@media screen and (min-width: 769px) {
  .ochugen_kv-keyword {
    top: 50%;
    margin-top: -5.1020408163vw;
    height: 10.2040816327vw;
  }
}
.ochugen_kv-keyword_txt {
  display: flex;
}
.ochugen_kv-keyword_txt p {
  font-family: "minion-pro", serif;
  color: #1b63b6;
  font-size: 21.25vw;
  font-weight: 500;
  line-height: 1;
  white-space: nowrap;
  animation: loop-kv 25s linear infinite;
  padding: 0 0.2em;
}
@media screen and (min-width: 769px) {
  .ochugen_kv-keyword_txt p {
    font-size: 9.387755102vw;
  }
}
.ochugen_kv-detail {
  position: absolute;
  top: 15.625vw;
  left: 0;
  width: 100%;
  display: grid;
  transform: translateY(0);
  opacity: 1;
  transition: 0.8s ease all;
}
@media screen and (min-width: 769px) {
  .ochugen_kv-detail {
    top: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
    padding-bottom: 10vw;
  }
}
.ochugen_kv-detail h2 {
  color: #1b63b6;
  font-family: "minion-pro", serif;
  font-size: 7.8125vw !important;
  text-align: center;
  margin-bottom: 5.3125vw !important;
}
@media screen and (min-width: 769px) {
  .ochugen_kv-detail h2 {
    font-size: 2.2448979592vw !important;
    margin-bottom: 0.9183673469vw !important;
  }
}
.ochugen_kv-pacage {
  margin: 0 auto;
  transform: translateY(0);
  opacity: 1;
  transition: 0.8s ease all;
}
@media screen and (min-width: 769px) {
  .ochugen_kv-pacage {
    width: fit-content;
  }
}
.ochugen_kv-pacage img {
  width: 71.875vw;
}
@media screen and (min-width: 769px) {
  .ochugen_kv-pacage img {
    width: 33.1632653061vw;
  }
}
.ochugen_kv-link {
  pointer-events: visible;
}
@media screen and (max-width: 768px) {
  .ochugen_kv-link {
    grid-area: 2/1/3/2;
  }
}
@media screen and (min-width: 769px) {
  .ochugen_kv-link {
    position: absolute;
    bottom: 2.5510204082vw;
    left: 50%;
    margin-left: -4.0816326531vw;
  }
}
.ochugen_kv-link a {
  display: block;
  width: 105px;
  height: 105px;
  background: url(https://gigaplus.makeshop.jp/cdcom/new2025/img/ochugen/slide_more.svg) no-repeat center/100% auto;
  margin: 0 auto 30px;
}
@media screen and (min-width: 769px) {
  .ochugen_kv-link a {
    width: 8.1632653061vw;
    height: 8.1632653061vw;
    margin: 3.5714285714vw auto 0;
  }
}
.ochugen_kv-link a svg {
  width: 100%;
  height: 100%;
  transform: rotate(-180deg);
  position: relative;
}
.ochugen_kv-link a svg .line-move {
  fill: none;
  stroke: #1b63b6;
  stroke-width: 1;
  stroke-dasharray: var(--progress);
  stroke-dashoffset: 0;
}
.ochugen_kv-link a svg .line-bg {
  fill: none;
  stroke: #fff;
  stroke-width: 1;
  stroke-dasharray: var(--progress);
  stroke-dashoffset: 0;
  position: absolute;
  top: 0;
  left: 0;
}

@keyframes circle {
  0% {
    stroke-dasharray: 0 var(--progress);
  }
  99% {
    stroke-dasharray: var(--progress) var(--progress);
  }
}
@keyframes loop-kv {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}
.mainArea {
  position: relative;
  padding: 21.875vw 0 29.6875vw;
  text-align: center;
  color: #1b63b6;
}
@media screen and (min-width: 769px) {
  .mainArea {
    padding: 18.5714285714vw 0 6.1224489796vw;
  }
}
.mainArea_logo {
  margin-bottom: 12.5vw;
}
@media screen and (min-width: 769px) {
  .mainArea_logo {
    margin-bottom: 2.5510204082vw;
  }
}
.mainArea_logo img {
  width: 31.25vw;
}
@media screen and (min-width: 769px) {
  .mainArea_logo img {
    width: 8.4693877551vw;
  }
}
.mainArea h1 {
  font-size: 9.375vw;
  font-family: "minion-pro", serif;
  margin-bottom: 15.625vw;
  line-height: 1.3;
}
@media screen and (min-width: 769px) {
  .mainArea h1 {
    font-size: 3.5714285714vw;
    margin-bottom: 3.5714285714vw;
  }
}
.mainArea h2 {
  font-size: 5.625vw !important;
  margin-bottom: 7.8125vw !important;
  font-weight: 600;
  font-family: var(--font-Mincho);
}
@media screen and (min-width: 769px) {
  .mainArea h2 {
    font-size: 1.8367346939vw !important;
    margin-bottom: 2.0408163265vw !important;
  }
}
.mainArea p {
  font-size: 3.75vw;
  letter-spacing: 0.03em;
  line-height: 2.2;
  margin-bottom: 21.875vw;
}
@media screen and (min-width: 769px) {
  .mainArea p {
    font-size: 1.0204081633vw;
    margin-bottom: 20.4081632653vw;
  }
}
.mainArea_img {
  overflow: hidden;
}
@media screen and (min-width: 769px) {
  .mainArea_img {
    position: absolute;
  }
}
.mainArea_img img {
  display: block;
  width: 100%;
  transition: 0.1s;
}
.mainArea_img-1 {
  height: 116.5625vw;
  width: 84.375vw;
}
@media screen and (min-width: 769px) {
  .mainArea_img-1 {
    height: 43.3673469388vw;
    width: 30.612244898vw;
    top: 18.7244897959vw;
    left: 0;
  }
}
.mainArea_img-2 {
  margin-top: -9.375vw;
  text-align: left;
  height: 53.125vw;
  width: 71.875vw;
}
@media screen and (min-width: 769px) {
  .mainArea_img-2 {
    height: 22.9591836735vw;
    width: 28.0612244898vw;
    top: 4.5918367347vw;
    right: 0;
    margin-top: 0;
  }
}
.mainArea_img-3 {
  text-align: right;
  margin: 15.625vw 0 0 auto;
  height: 67.8125vw;
  width: 75vw;
}
@media screen and (min-width: 769px) {
  .mainArea_img-3 {
    height: 25.5102040816vw;
    width: 30.612244898vw;
    top: 39.8979591837vw;
    right: 3.3163265306vw;
    margin: 0;
  }
}

.sec_ttl {
  text-align: center;
  font-family: "minion-pro", serif;
  font-size: 8.75vw !important;
  font-weight: 500;
  margin-bottom: 9.375vw !important;
  color: #1b63b6;
}
@media screen and (min-width: 769px) {
  .sec_ttl {
    font-size: 3.5714285714vw !important;
    margin-bottom: 3.9795918367vw !important;
  }
}

@media screen and (min-width: 769px) {
  .pickup li {
    display: flex;
  }
}
@media screen and (min-width: 769px) {
  .pickup li:nth-child(even) {
    flex-direction: row-reverse;
  }
}
.pickup li:nth-child(1) .pickup_img {
  background: url(https://gigaplus.makeshop.jp/cdcom/new2025/img/ochugen/pickup_bg1.webp) no-repeat center/cover;
}
.pickup li:nth-child(2) .pickup_img {
  background: url(https://gigaplus.makeshop.jp/cdcom/new2025/img/ochugen/pickup_bg2.webp) no-repeat center/cover;
}
.pickup li:nth-child(3) .pickup_img {
  background: url(https://gigaplus.makeshop.jp/cdcom/new2025/img/ochugen/pickup_bg3.webp) no-repeat center/cover;
}
.pickup li:nth-child(4) .pickup_img {
  background: url(https://gigaplus.makeshop.jp/cdcom/new2025/img/ochugen/pickup_bg4.webp) no-repeat center/cover;
}
.pickup_img {
  padding: 7.8125vw;
}
@media screen and (min-width: 769px) {
  .pickup_img {
    width: 50%;
    padding: 5.1020408163vw 0;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.pickup_img img {
  width: 84.375vw;
}
@media screen and (min-width: 769px) {
  .pickup_img img {
    width: 38.7755102041vw;
  }
}
.pickup_main {
  background-color: #1b63b6;
  color: #fff;
  padding: 6.25vw 6.25vw 6.25vw 7.8125vw;
}
@media screen and (min-width: 769px) {
  .pickup_main {
    width: 50%;
    padding: 4.3367346939vw 3.9795918367vw 4.3367346939vw 4.8469387755vw;
    display: flex;
    flex-direction: column;
  }
}
.pickup_main_top {
  display: flex;
  justify-content: center;
  flex-direction: row-reverse;
  justify-content: space-between;
}
.pickup_main_top dt {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  font-family: var(--font-Mincho);
  font-weight: 500;
  font-size: 3.125vw;
  line-height: 2;
}
@media screen and (min-width: 769px) {
  .pickup_main_top dt {
    font-size: 1.4285714286vw;
  }
}
.pickup_main_top dd {
  width: 62.5vw;
}
@media screen and (min-width: 769px) {
  .pickup_main_top dd {
    width: 25.5102040816vw;
  }
}
.pickup_main_top dd h3 {
  font-family: "minion-pro", serif;
  font-size: 7.5vw;
  line-height: 1.2;
}
@media screen and (min-width: 769px) {
  .pickup_main_top dd h3 {
    font-size: 2.3469387755vw;
  }
}
.pickup_main_top dd h4 {
  font-size: 3.125vw;
  line-height: 2.2;
  letter-spacing: 0.08em;
  word-break: normal;
  margin-top: 9.375vw;
  margin-bottom: 3.75vw;
}
@media screen and (min-width: 769px) {
  .pickup_main_top dd h4 {
    font-size: 0.9183673469vw;
    margin-top: 2.0408163265vw;
    margin-bottom: 2.0408163265vw;
  }
}
.pickup_main_memo {
  border-top: 1px solid #fff;
  margin-top: 7.5vw;
  padding-top: 3.75vw;
  font-size: 2.8125vw;
  font-weight: 500;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  .pickup_main_memo {
    font-size: max(12px, 0.7142857143vw);
    margin-top: 1.0204081633vw;
    padding-top: 1.0204081633vw;
    border-top-width: 1.5px;
  }
}

.tag {
  display: flex;
  gap: 2.8125vw;
}
@media screen and (min-width: 769px) {
  .tag {
    gap: 0.9183673469vw;
  }
}
.tag span {
  font-size: 2.65625vw;
  color: #1b63b6;
  background-color: #fff;
  padding: 1.25vw 2.5vw;
  border-radius: 0.46875vw;
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .tag span {
    font-size: max(12px, 0.8673469388vw);
    padding: 0.4081632653vw 0.7142857143vw;
    border-radius: 1.5px;
  }
}

.price {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 3.75vw 3.125vw;
  align-items: center;
  margin-top: 9.375vw;
}
@media screen and (min-width: 769px) {
  .price {
    gap: 1.2755102041vw 0.612244898vw;
    margin-top: auto;
  }
}
.price dt {
  font-weight: 700;
  display: flex;
  align-items: baseline;
}
.price dt small {
  font-size: 2.5vw;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 769px) {
  .price dt small {
    font-size: 0.8673469388vw;
  }
}
.price dt b {
  font-size: 4.6875vw;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 769px) {
  .price dt b {
    font-size: 1.6326530612vw;
  }
}

.btn--more {
  font-size: 2.1875vw;
  font-weight: 700;
  width: fit-content;
  letter-spacing: 0.1em;
  padding: 0 3.75vw;
  height: 6.875vw;
  border-radius: 6.875vw;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #fff;
  transition: 0.3s;
}
@media screen and (min-width: 769px) {
  .btn--more {
    font-size: 0.8163265306vw;
    height: 2.2959183673vw;
    border-radius: 1.5306122449vw;
    padding: 0 1.2755102041vw;
    border-width: 1.5px;
  }
}
@media (hover) {
  .btn--more:hover {
    background-color: #fff;
    color: #1b63b6;
    opacity: 1 !important;
  }
}
.btn--more-br {
  color: #1b63b6;
  border-color: #1b63b6;
}
@media (hover) {
  .btn--more-br:hover {
    background-color: #1b63b6;
    color: #fff;
  }
}

#gift, #lineup {
  padding: 29.6875vw 0 0;
}
@media screen and (min-width: 769px) {
  #gift, #lineup {
    padding: 14.7959183673vw 0 0;
  }
}

.gift_item li {
  background-color: #f0f0f0;
}
@media screen and (min-width: 769px) {
  .gift_item li {
    display: flex;
    justify-content: space-between;
  }
}
.gift_item li:nth-child(odd) {
  border-top-right-radius: 2.5vw;
  border-bottom-right-radius: 2.5vw;
  margin-right: 2.5vw;
  padding: 7.8125vw 5.3125vw 20.3125vw 7.8125vw;
}
@media screen and (min-width: 769px) {
  .gift_item li:nth-child(odd) {
    border-top-right-radius: 1.0204081633vw;
    border-bottom-right-radius: 1.0204081633vw;
    margin-right: 10.2040816327vw;
    padding: 7.1428571429vw 7.1428571429vw 7.1428571429vw 9.693877551vw;
    flex-direction: row-reverse;
  }
}
.gift_item li:nth-child(even) {
  border-top-left-radius: 2.5vw;
  border-bottom-left-radius: 2.5vw;
  margin-left: 2.5vw;
  padding: 7.8125vw 7.8125vw 20.3125vw 5.3125vw;
}
@media screen and (min-width: 769px) {
  .gift_item li:nth-child(even) {
    border-top-left-radius: 1.0204081633vw;
    border-bottom-left-radius: 1.0204081633vw;
    margin-left: 10.2040816327vw;
    padding: 7.1428571429vw 7.1428571429vw 9.693877551vw 7.1428571429vw;
  }
}
.gift_item li + li {
  margin-top: 10.9375vw;
}
@media screen and (min-width: 769px) {
  .gift_item li + li {
    margin-top: 7.6530612245vw;
  }
}
.gift_item li figure {
  margin-bottom: 7.8125vw;
}
@media screen and (min-width: 769px) {
  .gift_item li figure {
    margin-bottom: 0;
    width: 31.6326530612vw;
  }
}
.gift_item li figure img {
  width: 100%;
}
.gift_item li h3 {
  font-family: var(--font-Mincho);
  font-size: 4.375vw;
  color: #1b63b6;
  font-weight: 500;
  line-height: 1.8;
  margin-bottom: 6.25vw;
}
@media screen and (min-width: 769px) {
  .gift_item li h3 {
    font-size: 1.8367346939vw;
    margin-bottom: 1.5306122449vw;
  }
}
.gift_item li p {
  font-size: 3.125vw;
  line-height: 2.5;
  letter-spacing: 0.1em;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  .gift_item li p {
    font-size: 1.1224489796vw;
  }
}
.gift_item li a {
  margin: 6.25vw 0 0;
}
@media screen and (min-width: 769px) {
  .gift_item li a {
    margin: 1.7857142857vw 0 0;
  }
}
.gift_item li span {
  display: inline-block;
  background-color: #1b63b6;
  color: #fff;
  font-size: 2.5vw;
  padding: 1.5625vw 2.5vw;
  border-radius: 0.625vw;
  font-weight: 700;
  margin-bottom: 5.625vw;
}
@media screen and (min-width: 769px) {
  .gift_item li span {
    font-size: 0.8673469388vw;
    padding: 0.4081632653vw 0.7653061224vw;
    border-radius: 0.2551020408vw;
    margin-bottom: 1.2755102041vw;
  }
}
@media screen and (min-width: 769px) {
  .gift_detail {
    width: 34.693877551vw;
  }
}

#lineup {
  overflow: hidden;
}

.lineup_main {
  margin-bottom: 12.5vw;
}
@media screen and (min-width: 769px) {
  .lineup_main {
    margin-bottom: 5.1020408163vw;
  }
}
.lineup_main img {
  width: 100%;
}
@media screen and (min-width: 769px) {
  .lineup_main img {
    width: 87.7551020408vw;
  }
}
.lineup_ttl {
  margin: 0 7.8125vw 12.5vw;
}
@media screen and (min-width: 769px) {
  .lineup_ttl {
    margin: 0 10.2040816327vw 5.1020408163vw;
    display: flex;
    flex-direction: row-reverse;
    align-items: center;
    justify-content: space-between;
  }
}
.lineup_ttl dt {
  font-family: var(--font-Mincho);
  font-size: 5.625vw;
  margin-bottom: 9.375vw;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  .lineup_ttl dt {
    writing-mode: vertical-rl;
    text-orientation: mixed;
    font-size: 2.3979591837vw;
    margin-bottom: 0;
    line-height: 2.3;
    margin-right: 4.0816326531vw;
  }
}
.lineup_ttl dd {
  font-size: 3.4375vw;
  line-height: 2.5;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  .lineup_ttl dd {
    font-size: 1.3265306122vw;
  }
}
.lineup_product {
  border-top: 1px solid rgba(27, 99, 182, 0.3);
  padding-top: 6.25vw;
  margin-top: 7.8125vw;
}
@media screen and (min-width: 769px) {
  .lineup_product {
    padding-top: 2.0408163265vw;
    margin-top: 4.5918367347vw;
    border-top-width: 1.5px;
  }
}
.lineup_product:has(.slick-arrow) {
  margin-top: 20.3125vw;
}
@media screen and (min-width: 769px) {
  .lineup_product:has(.slick-arrow) {
    margin-top: 7.1428571429vw;
  }
}
.lineup_product .slick-arrow {
  font-size: 0;
  line-height: 0;
  color: transparent;
  border: none;
  width: 7.8125vw;
  height: 7.8125vw;
  background: url(https://gigaplus.makeshop.jp/cdcom/new2025/img/ochugen/arrow_slide.svg) no-repeat center/100% auto;
  top: auto;
  bottom: calc(100% + 3.75vw);
}
@media screen and (min-width: 769px) {
  .lineup_product .slick-arrow {
    width: 28px;
    height: 28px;
    bottom: calc(100% + 20px);
  }
}
.lineup_product .slick-arrow.slick-disabled {
  opacity: 0.3;
}
.lineup_product .slick-prev {
  transform: scale(-1, 1);
  left: auto;
  right: 14.0625vw;
}
@media screen and (min-width: 769px) {
  .lineup_product .slick-prev {
    right: 60px;
  }
}
.lineup_product .slick-next {
  transform: none;
}
@media screen and (min-width: 769px) {
  .lineup_product .slick-next {
    right: 20px;
  }
}
.lineup_block {
  border-top: 1px solid #1b63b6;
}
@media screen and (min-width: 769px) {
  .lineup_block {
    border-width: 1.5px;
  }
}
.lineup_item {
  padding-top: 12.5vw;
  margin: 0 7.8125vw 18.75vw;
  position: relative;
}
@media screen and (min-width: 769px) {
  .lineup_item {
    padding-top: 6.6326530612vw;
    margin: 0 auto 7.6530612245vw;
    width: 77.5510204082vw;
  }
}
.lineup_item_ttl {
  font-family: "minion-pro", serif;
  color: #1b63b6;
  font-weight: 500;
  font-size: 8.125vw;
  line-height: 1.2;
  margin-bottom: 9.375vw;
  text-transform: uppercase;
}
@media screen and (min-width: 769px) {
  .lineup_item_ttl {
    font-size: 3.5714285714vw;
    margin-bottom: 2.0408163265vw;
  }
}
.lineup_item_lead {
  font-size: 3.125vw;
  line-height: 2.2;
  width: 75vw;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  .lineup_item_lead {
    font-size: 1.1224489796vw;
    width: 45.4081632653vw;
    line-height: 2.6;
  }
}
.lineup_item_side {
  font-size: 3.125vw;
  font-family: var(--font-Mincho);
  font-weight: 500;
  writing-mode: vertical-rl;
  text-orientation: mixed;
  position: absolute;
  right: 0;
  top: 12.5vw;
  color: #1b63b6;
}
@media screen and (min-width: 769px) {
  .lineup_item_side {
    font-size: 1.2755102041vw;
    top: 6.6326530612vw;
  }
}
.lineup_product-item {
  display: flex;
  flex-direction: column;
}
.lineup_product-item a {
  display: block;
}
@media (hover) {
  .lineup_product-item a:hover .btn--more {
    background-color: #1b63b6;
    color: #fff;
  }
}
.lineup_product-item figure {
  position: relative;
  margin-bottom: 2.5vw;
}
@media screen and (min-width: 769px) {
  .lineup_product-item figure {
    margin-bottom: 0.7653061224vw;
  }
}
.lineup_product-item figure span {
  background-color: #808080;
  color: #fff;
  padding: 1.5625vw 1.25vw 1.25vw;
  font-size: 2.8125vw;
  line-height: 1;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media screen and (min-width: 769px) {
  .lineup_product-item figure span {
    padding: 0.2551020408vw 0.2040816327vw 0.2040816327vw;
    font-size: 0.8673469388vw;
  }
}
.lineup_product-item figure img {
  width: 100%;
}
.lineup_product-item h4 {
  font-size: 3.4375vw;
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 1.5625vw;
}
@media screen and (min-width: 769px) {
  .lineup_product-item h4 {
    margin-bottom: 0.306122449vw;
    font-size: 1.1224489796vw;
  }
}
.lineup_product-item p {
  display: flex;
  align-items: center;
  font-size: 3.75vw;
  font-weight: 500;
  column-gap: 1.5625vw;
  margin-bottom: 2.5vw;
}
@media screen and (min-width: 769px) {
  .lineup_product-item p {
    column-gap: 0.612244898vw;
    font-size: 1.2244897959vw;
    margin-bottom: 0.7653061224vw;
  }
}
.lineup_product-item p small {
  font-size: 2.1875vw;
  color: #808080;
  transform: translateY(0.1em);
}
@media screen and (min-width: 769px) {
  .lineup_product-item p small {
    font-size: max(10px, 0.7142857143vw);
  }
}
.lineup_product-item .btn--more {
  margin-top: auto;
  font-size: 2.5vw;
}
@media screen and (min-width: 769px) {
  .lineup_product-item .btn--more {
    font-size: max(10px, 0.7142857143vw);
  }
}
.lineup_product .slick-list {
  margin: 0 -7.8125vw 0 -1.5625vw;
}
@media screen and (min-width: 769px) {
  .lineup_product .slick-list {
    margin: 0 -0.6632653061vw;
  }
}
@media screen and (max-width: 768px) {
  .lineup_product .slick-list {
    overflow: visible;
    padding-right: 7.8125vw;
  }
}
.lineup_product .slick-slide {
  margin: 0 1.5625vw;
}
@media screen and (min-width: 769px) {
  .lineup_product .slick-slide {
    margin: 0 0.6632653061vw;
  }
}

.search_img {
  position: relative;
}
.search_img h2 {
  position: absolute;
  left: 7.8125vw;
  top: 7.8125vw;
  font-size: 5.625vw !important;
  margin: 0 !important;
  font-family: var(--font-Mincho);
  font-weight: 500;
  line-height: 1.8;
  color: #fff;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .search_img h2 {
    left: 9.693877551vw;
    top: 5.1020408163vw;
    font-size: 2.3469387755vw !important;
    letter-spacing: 0.1em;
  }
}
.search_slide {
  display: flex;
  align-items: center;
  width: 100%;
  overflow: hidden;
}
.search_slide_block {
  animation: slide_img 80s linear infinite;
  will-change: transform;
  white-space: nowrap;
  display: flex;
  align-items: center;
}
.search_slide figure {
  white-space: nowrap;
  display: block;
}
.search_slide figure img {
  max-width: none;
  width: 286.25vw;
}
@media screen and (min-width: 769px) {
  .search_slide figure img {
    width: 115.612244898vw;
  }
}
.search_item {
  display: flex;
  flex-direction: column;
  row-gap: 12.5vw;
  position: relative;
  padding: 14.0625vw 7.8125vw;
}
@media screen and (min-width: 769px) {
  .search_item {
    padding: 7.6530612245vw 15.306122449vw;
    row-gap: 0;
    display: grid;
    grid-template-columns: 25vw 31.6326530612vw 1fr;
  }
}
.search_item h3 {
  font-family: "minion-pro", serif;
  color: #1b63b6;
  font-size: 8.125vw;
  font-weight: 500;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .search_item h3 {
    font-size: 3.5714285714vw;
  }
}
.search_item_btn {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4.6875vw;
}
@media screen and (min-width: 769px) {
  .search_item_btn {
    gap: 1.7857142857vw;
  }
}
.search_item_btn a {
  display: block;
  color: #1b63b6;
  border: 1px solid #1b63b6;
  padding: 1.875vw 3.125vw;
  font-size: 3.125vw;
  font-weight: 700;
  letter-spacing: 0.05em;
  border-radius: 9.375vw;
  text-align: center;
  transition: 0.3s;
}
@media screen and (min-width: 769px) {
  .search_item_btn a {
    font-size: 1.1734693878vw;
    padding: 0.5102040816vw 0.5102040816vw;
    border-radius: 2.5510204082vw;
    border-width: 1.5px;
  }
}
@media (hover) {
  .search_item_btn a:hover {
    background-color: #1b63b6;
    color: #fff;
    opacity: 1 !important;
  }
}
.search_item h4 {
  position: absolute;
  top: 14.0625vw;
  right: 7.8125vw;
  font-family: var(--font-Mincho);
  color: #1b63b6;
  font-size: 3.125vw;
  font-weight: 500;
  line-height: 2;
  writing-mode: vertical-rl;
}
@media screen and (min-width: 769px) {
  .search_item h4 {
    position: static;
    font-size: 1.2755102041vw;
    margin-left: auto;
  }
}
.search_item + .search_item {
  border-top: 1px solid #1b63b6;
}
@media screen and (min-width: 769px) {
  .search_item + .search_item {
    border-top-width: 1.5px;
  }
}

@keyframes slide_img {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}
.campaign {
  background: url(https://gigaplus.makeshop.jp/cdcom/new2025/img/ochugen/cam_bg.webp) no-repeat center/cover;
  padding: 15.625vw 7.8125vw;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .campaign {
    padding: 14.7959183673vw 0;
  }
}
@media screen and (min-width: 769px) {
  .campaign_in {
    width: 57.1428571429vw;
    margin: 0 auto;
  }
}
.campaign_badge {
  width: fit-content;
  margin: -7.8125vw auto 6.25vw;
  background-color: #1b63b6;
  color: #fff;
  font-size: 4.0625vw;
  font-weight: 700;
  padding: 0.625vw 3.125vw 1.25vw;
  border-radius: 1.25vw;
  display: block;
}
@media screen and (min-width: 769px) {
  .campaign_badge {
    margin: -3.5714285714vw auto 2.0408163265vw;
    font-size: 1.3265306122vw;
    padding: 0.1020408163vw 1.2244897959vw 0.2040816327vw;
    border-radius: 6px;
  }
}
.campaign_lead {
  font-family: var(--font-Mincho);
  font-size: 5.625vw;
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.6;
  margin-bottom: 6.25vw;
  color: #1b63b6;
}
@media screen and (min-width: 769px) {
  .campaign_lead {
    font-size: 2.3979591837vw;
    margin-bottom: 3.8265306122vw;
  }
}
.campaign_detail {
  background-color: #fff;
  padding: 12.5vw 7.8125vw 15.625vw;
  border-radius: 1.25vw;
  line-height: 1.2;
}
@media screen and (min-width: 769px) {
  .campaign_detail {
    padding: 4.0816326531vw 5.1020408163vw 5.1020408163vw;
    border-radius: 7px;
    line-height: 1.15;
  }
}
.campaign_detail_ttl {
  color: #f57900;
  margin-bottom: 6.25vw;
}
@media screen and (min-width: 769px) {
  .campaign_detail_ttl {
    margin-bottom: 2.806122449vw;
  }
}
.campaign_detail_ttl strong {
  font-size: 19.0625vw;
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .campaign_detail_ttl strong {
    font-size: 8.4693877551vw;
  }
}
.campaign_detail_ttl span {
  font-size: 11.5625vw;
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .campaign_detail_ttl span {
    font-size: 5.2040816327vw;
  }
}
.campaign_detail_ttl small {
  font-size: 6.875vw;
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .campaign_detail_ttl small {
    font-size: 2.6020408163vw;
  }
}
.campaign_detail_list {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 769px) {
  .campaign_detail_list {
    display: grid;
    grid-template-columns: 14.387755102vw 1fr;
    align-items: center;
    gap: 2.5510204082vw 2.2959183673vw;
    border-top: 1.5px solid #1b63b6;
    padding: 4.0816326531vw 2.5510204082vw 2.5510204082vw;
  }
}
.campaign_detail_list dt {
  font-size: 3.125vw;
  font-weight: 700;
  border: 1px solid #1b63b6;
  padding: 1.25vw;
  border-radius: 9.375vw;
  color: #1b63b6;
  margin-bottom: 1.875vw;
}
@media screen and (min-width: 769px) {
  .campaign_detail_list dt {
    font-size: 1.1224489796vw;
    border-radius: 1.5306122449vw;
    margin-bottom: 0;
    padding: 0.612244898vw;
    border-width: 1.5px;
  }
}
.campaign_detail_list dd {
  font-size: 4.0625vw;
  font-weight: 700;
  margin-bottom: 5vw;
  color: #1b63b6;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 769px) {
  .campaign_detail_list dd {
    font-size: 1.5816326531vw;
    margin-bottom: 0;
    text-align: left;
    letter-spacing: 0.05em;
  }
}
.campaign_detail_list dd small {
  display: block;
  font-size: 2.5vw;
  margin-top: 1.5625vw;
}
@media screen and (min-width: 769px) {
  .campaign_detail_list dd small {
    font-size: 0.9693877551vw;
    margin-top: 0.8em;
  }
}
.campaign_detail_code {
  border-top: 1px solid #1b63b6;
  padding-top: 6.25vw;
}
@media screen and (min-width: 769px) {
  .campaign_detail_code {
    padding-top: 3.0612244898vw;
    border-top-width: 1.5px;
  }
}
.campaign_detail_code p {
  color: #1b63b6;
  font-weight: 700;
  font-size: 4.375vw;
  margin-bottom: 3.125vw;
}
@media screen and (min-width: 769px) {
  .campaign_detail_code p {
    font-size: 1.9387755102vw;
    margin-bottom: 1.0204081633vw;
  }
}
.campaign_detail_code button {
  -webkit-appearance: none;
  appearance: none;
  background-color: #1b63b6;
  color: #fff;
  width: 59.375vw;
  height: 12.5vw;
  border-radius: 1.25vw;
  position: relative;
  border: 1px solid #1b63b6;
  font-size: 5vw;
  font-weight: 700;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition: 0.3s;
}
@media screen and (min-width: 769px) {
  .campaign_detail_code button {
    font-size: 2.2448979592vw;
    width: 26.6326530612vw;
    height: 5.306122449vw;
    border-radius: 6px;
    border-width: 1.5px;
  }
}
.campaign_detail_code button i {
  position: absolute;
  right: 2.5vw;
  top: 50%;
  margin-top: -1.875vw;
  line-height: 1;
  font-size: 0;
}
@media screen and (min-width: 769px) {
  .campaign_detail_code button i {
    right: 1.0204081633vw;
    margin-top: -0.6632653061vw;
  }
}
.campaign_detail_code button i svg {
  width: 3.75vw;
  height: 3.75vw;
}
@media screen and (min-width: 769px) {
  .campaign_detail_code button i svg {
    width: 1.3265306122vw;
    height: 1.3265306122vw;
  }
}
@media (hover) {
  .campaign_detail_code button:hover {
    background-color: #fff;
    color: #1b63b6;
  }
  .campaign_detail_code button:hover i .icon_copy path, .campaign_detail_code button:hover i .icon_copy rect {
    stroke: #1b63b6;
  }
}
.campaign_detail_comp {
  color: #58c674;
  font-weight: 700;
  margin-top: 2.5vw;
  font-size: 3.75vw;
  opacity: 0;
  transition: 0.3s;
}
@media screen and (min-width: 769px) {
  .campaign_detail_comp {
    margin-top: 1.0204081633vw;
    font-size: 1.1224489796vw;
  }
}

.icon_copy path, .icon_copy rect {
  fill: none;
  stroke: #fff;
  stroke-linejoin: round;
  stroke-width: 0.7px;
  transition: 0.3s;
}

footer {
  margin-top: 0;
}

.lineup_product-tag {
  font-size: 2.65625vw;
  color: #fff;
  background-color: #808080;
  padding: 0.625vw 1.875vw 0.3125vw;
  border-radius: 0.46875vw;
  font-weight: 700;
  display: inline-block;
  transform: translateY(-1.875vw);
}
@media screen and (min-width: 769px) {
  .lineup_product-tag {
    font-size: max(11px, 0.8163265306vw);
    padding: 0.1530612245vw 0.7142857143vw 0.1020408163vw;
    margin-bottom: 0.306122449vw;
    border-radius: 1.5px;
    transform: translateY(-0.306122449vw);
  }
}/*# sourceMappingURL=ochugen.css.map */