@charset "utf-8";

/*===================
online
===================*/
.online {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.online.hidden {
  opacity: 0;
  visibility: hidden;
}
.online__link {
  display: block;
  /* width: 13.8vw;
  padding-top: 13.95%; */
  width: 230px;
  height: 230px;
  position: fixed;
  right: 30px;
  bottom: 10px;
  z-index: 3;
  background: url(../imgs/common/online_fixed.png) center center / cover no-repeat;
  transition: 0.3s;
}
.online__link:hover {
  background: url(../imgs/common/online_fixed_hover.png) center center / cover no-repeat;
}
@media screen and (max-width: 750px) {
  .online__link {
    width: 150px;
    height: 150px;
    right: 0;
  }
}

/*===================
fv
===================*/
.fv {
  position: relative;
  z-index: 1;
}
.fv__swiper {
  width: 85%;
  max-width: 1500px;
  margin: 0 auto;
}

/* スライド↓ */
/* ページネーションの余白 */
.fv__swiper .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet,
.fv__swiper .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 10px 9px;
}
/* ページネーションのサイズと色 */
.fv__swiper .swiper-pagination-bullet {
  background-color: #fff;
  height: 7px;
  width: 7px;
}
/* スライド↑ */
@media screen and (max-width: 750px) {
  .fv__swiper {
    width: 100%;
  }
}

/*===================
intro
===================*/
.intro {
  padding-top: 61px;
  padding-bottom: 92px;
}
.intro__box {
  margin-right: 44px;
  display: flex;
  justify-content: space-between;
  position: relative;
}
.intro__title {
  max-width: 125px;
  width: 11%;
  position: absolute;
  top: -91px;
  left: 0;
  z-index: 1;
}
.intro__contents {
  flex: 1;
  padding-left: 14%;
  padding-right: 20px;
}
.intro__heading {
  margin-bottom: 14px;
  font-size: clamp(17px, 1.736vw, 25px);
  font-weight: 700;
  line-height: 2.2;
  letter-spacing: 0.02em;
}
.intro__heading--lrg {
  font-size: clamp(27px, 2.2916vw, 33px);
  font-weight: 900;
  line-height: 1.2;
  letter-spacing: 0.03em;
}
.intro__text {
  font-size: clamp(15px, 1.319vw, 19px);
  font-weight: 700;
  line-height: 2.052;
}
.intro__map {
  max-width: 400px;
  width: 35%;
  padding-top: 28px;
}
@media screen and (max-width: 750px) {
  .intro {
    padding-top: 30px;
    padding-bottom: 47px;
  }
  .intro__box {
    padding-left: 14px;
    margin-right: 0;
    flex-direction: column-reverse;
    row-gap: 11px;
  }
  .intro__title {
    max-width: 73px;
    width: 25%;
    top: -79px;
    left: 6px;
  }
  .intro__map {
    width: 95%;
    padding-top: 0;
    padding-left: 19%;
  }
  .intro__contents {
    width: 100%;
    padding: 0;
  }
  .intro__heading {
    margin-bottom: 7px;
    font-size: 23px;
    line-height: 1.7;
  }
  .intro__size {
    font-size: 17px;
  }
  .intro__text {
    line-height: 1.8;
  }
}
/*===================
news
===================*/
.news {
  padding: 54px 0 54px;
  background: #28375e;
  color: #fff;
  overflow: hidden;
}
.news .inner-1220 {
  position: relative;
}
.news__deco01 {
  position: absolute;
  top: -25px;
  right: -148px;
  max-width: 300px;
  width: 25%;
}
.news__deco02 {
  position: absolute;
  bottom: -54px;
  left: -189px;
  max-width: 440px;
  width: 37%;
}
.news__title {
  margin-bottom: 32px;
  font-size: 25px;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-align: center;
}
.news__list {
  max-width: 700px;
  margin: 0 auto 50px;
  position: relative;
  z-index: 1;
}
.news__item {
  border-top: 1px solid #fff;
}
.news__item:last-child {
  border-bottom: 1px solid #fff;
}
.news__itemLink {
  display: flex;
  padding: 26px 60px 22px 10px;
  position: relative;
}
.news__itemLink::before {
  content: "";
  display: block;
  width: 15px;
  height: 5px;
  border: none;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-50%) skew(45deg);
  transition: 0.3s;
}
.news__itemLink:hover.news__itemLink::before {
  right: 10px;
  width: 35px;
}
.news__date {
  display: block;
  width: 160px;
  font-size: 19px;
  font-weight: 600;
  letter-spacing: 0.07em;
  line-height: 1.1;
}
.news__itemTitle {
  flex: 1;
  font-size: 19px;
  font-weight: 600;
  line-height: 1.1;
}
.news__btn {
}
.news__btnLink {
  display: block;
  max-width: 230px;
  padding: 17px 5px 19px 20px;
  margin: 0 auto;
  border: 1px solid #fff;
  font-size: 19px;
  font-weight: 600;
  position: relative;
  transition: 0.3s;
}
.news__btnLink::before {
  content: "";
  display: block;
  width: 15px;
  height: 5px;
  border: none;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-50%) skew(45deg);
  transition: 0.3s;
}
.news__btnLink:hover {
  background: #fff;
  border-radius: 15px;
  color: #003161;
}
.news__btnLink:hover.news__btnLink::before {
  border-right: 1px solid #003161;
  border-bottom: 1px solid #003161;
  right: 10px;
  width: 25px;
}
@media screen and (max-width: 750px) {
  .news {
    padding: 35px 0 33px;
  }
  .news__deco01 {
    width: 42%;
    max-width: 150px;
    top: -16px;
    right: -53px;
  }
  .news__deco02 {
    width: 60%;
    max-width: 198px;
    bottom: -33px;
    left: -40px;
  }
  .news__title {
    margin-bottom: 21px;
    font-size: 23px;
  }
  .news__list {
    margin-bottom: 27px;
  }
  .news__itemLink {
    padding: 13px 0 10px;
    flex-direction: column;
    row-gap: 10px;
  }
  .news__itemLink::before {
    display: none;
  }
  .news__date {
    width: 100%;
    font-size: 14px;
  }
  .news__itemTitle {
    width: 100%;
    font-size: 14px;
  }
  .news__btnLink {
    max-width: 180px;
    padding: 12px 5px 16px 15px;
    font-size: 15px;
  }
  .news__btnLink::before {
    right: 23px;
  }
}

/*===================
product
===================*/
.product {
  padding: 80px 0 0px;
  background: url(../imgs/index/bg.jpg) center center / 100% auto repeat;
}
.product__ttl {
  max-width: 310px;
  margin: 0 auto 24px;
}
.product__txt {
  width: fit-content;
  margin: 0 auto 27px;
  padding: 12px 5px 13px;
  border-top: 2px solid #003161;
  border-bottom: 2px solid #003161;
  font-size: 19px;
  font-weight: 600;
  letter-spacing: 0.05em;
}
.product__redBtn {
  max-width: 500px;
  margin: 0 auto 11px;
}
.product__redBtnLink {
  display: block;
  padding: 26px 30px 25px;
  background: #c92a28;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: #fff;
  position: relative;
  transition: 0.3s;
}
.product__redBtnLink::before {
  content: "";
  display: block;
  width: 15px;
  height: 5px;
  border: none;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  position: absolute;
  top: 50%;
  right: 50px;
  transform: translateY(-50%) skew(45deg);
  transition: 0.3s;
}
.product__redBtnLink:hover {
  border-radius: 15px;
}
.product__redBtnLink:hover.product__redBtnLink::before {
  right: 30px;
  width: 35px;
}

.product__item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding-top: 120px;
  padding-bottom: 76px;
  border-bottom: 1px solid #003161;
}
.product__item:first-child {
  padding-top: 0;
}
.product__item:last-child {
  border-bottom: none;
}
.product__item:nth-child(even) {
  flex-direction: row-reverse;
}
.product__item.top-fish-roe {
  align-items: flex-end;
}
.product__contents.relative {
  position: relative;
}
.product__productMainTtl {
  width: clamp(60px, 5.555vw, 80px);
  height: clamp(200px, 18.472vw, 266px);
  background: url(../imgs/index/title_bg.png) center center / cover no-repeat;
  display: flex;
  align-items: center;
  text-align: center;
  font-size: clamp(27px, 2.777vw, 40px);
  font-weight: 700;
  letter-spacing: 0.3em;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  color: #fff;
  text-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3);

  position: absolute;
  top: -14%;
  left: 0;
}
.top-crab-shrimp .product__productMainTtl {
  letter-spacing: 0.05em;
}
.top-processed .product__productMainTtl {
  letter-spacing: 0.05em;
}
.top-crab-shrimp .product__productMainTtl span {
  padding-top: clamp(10px, 1.18vw, 17px);
}
.productPage__productMainPic {
  margin-top: -20px;
}
.product__productMainTtl span {
  padding-top: clamp(22px, 2.777vw, 40px);
  transform: translate(-1px, 0px);
}
.product__contents {
  width: 60%;
  padding-left: 9%;
  margin-bottom: 25px;
}

.product__pic {
  width: 36%;
}
.top-fresh-fish .product__pic {
  position: relative;
}
.top-processed .product__pic {
  padding-top: 80px;
}
.top-fresh-fish .product__pic .img {
  position: absolute;
  top: 25px;
  left: -8px;
  width: 141%;
  max-width: 620px;
}
.top-crab-shrimp .product__pic {
  position: relative;
}
.top-crab-shrimp .product__pic .img {
  position: absolute;
  top: -100px;
  left: -14px;
  width: 103%;
  max-width: 452px;
}
.product__text {
  padding-bottom: 22px;
  border-bottom: 1px solid #003161;
  margin-bottom: 22px;
  font-size: 19px;
  font-weight: 600;
  line-height: 1.7368;
}
.product__handle {
  padding-left: 30px;
  margin-bottom: 12px;
  font-size: 19px;
  font-weight: 700;
  position: relative;
}
.product__handle::before {
  display: block;
  content: "";
  width: 25px;
  height: 25px;
  background: url(../imgs/index/icon_circle.png) center center / cover no-repeat;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
}
.product__handleBox {
  max-width: 459px;
  margin-bottom: 51px;
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 8px;
}

.product__handleItem {
  width: fit-content;
  padding: 4px 12px 4px 13px;
  background: #003161;
  border-radius: 5px;
  font-size: 19px;
  font-weight: 700;
  color: #fff;
}
.product__handleEtc {
  display: block;
  min-width: fit-content;
  font-size: 19px;
  font-weight: 700;
}
.product__btnBox {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.product__btn {
  width: 49%;
}
.product__link {
  display: block;
  max-width: 300px;
  padding: 8px 49px 8px 11px;
  background: #fff;
  border: 1px solid #003161;
  font-size: clamp(17px, 1.319vw, 19px);
  font-weight: 700;
  color: #003161;
  transition: 0.3s;
  position: relative;
}
.product__link::before {
  display: block;
  content: "";
  width: 16px;
  height: 6px;
  background: url(../imgs/product/arrow_b.png) center center / cover no-repeat;
  position: absolute;
  top: 50%;
  right: 25px;
  transform: translate(0, -50%);
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
}
.product__link:hover {
  background: #c92a28;
  border: 1px solid #c92a28;
  border-radius: 10px;
  color: #fff;
  transition: 0.3s;
}

.product__link.--type02:hover {
  background: #003161;
  border: 1px solid #003161;
}
.product__link:hover.product__link::before {
  background: url(../imgs/product/arrow_w.png) center center / cover no-repeat;
}
@media screen and (max-width: 1230px) {
  .product__redBtn {
    margin-bottom: 70px;
  }
  .product__btnBox {
    flex-direction: column;
    row-gap: 10px;
  }
  .product__btn {
    width: 100%;
  }
}
@media screen and (max-width: 750px) {
  .product {
    padding: 47px 0 0px;
    overflow: hidden;
  }
  .product__ttl {
    max-width: 249px;
    margin-bottom: 20px;
  }
  .product__txt {
    width: 100%;
    max-width: 320px;
    padding: 14px 10px 17px;
    margin-bottom: 19px;
    font-size: 17px;
    text-align: center;
  }
  .product__redBtn {
    max-width: 320px;
    margin-bottom: 12px;
  }
  .product__redBtnLink {
    padding: 25px 35px 28px 15px;
    margin-bottom: 26px;
    font-size: 15px;
  }
  .product__redBtnLink::before {
    right: 12px;
  }
  .product__productMainTtl {
    top: 1%;
  }
  .product__item,
  .product__item:nth-child(even) {
    flex-direction: column-reverse;
    position: relative;
  }
  .product__item {
    padding-bottom: 41px;
    border-bottom: none;
  }
  .product__item.top-crab-shrimp,
  .product__item.top-processed {
    padding-top: 0;
  }
  .product__item.top-fish-roe {
    align-items: flex-start;
  }
  .product__pic {
    width: 81%;
    max-width: 390px;
    margin-left: 50px;
  }
  .top-fresh-fish .product__pic {
    width: 93%;
  }
  .top-fresh-fish .product__pic .img {
    position: static;
    width: 100%;
  }
  .top-crab-shrimp .product__pic .img {
    position: static;
    width: 100%;
  }
  .product__contents {
    width: 100%;
    padding-left: 0;
  }
  .product__contents.relative {
    position: static;
  }
  .product__text {
    padding-bottom: 19px;
    margin-bottom: 13px;
    font-size: 14px;
    line-height: 1.428;
  }
  .product__handleBox {
    max-width: none;
    margin-bottom: 21px;
    gap: 3px;
  }
  .product__handle {
    font-size: 17px;
  }
  .product__handleItem {
    font-size: 14px;
  }
  .product__handleEtc {
    font-size: 14px;
  }
  .product__link {
    max-width: 320px;
  }
  .product__link::before {
    right: 16px;
  }
}
/*===================
order
===================*/
.order {
  padding: 70px 0 150px;
}
.order__ttl {
  max-width: 518px;
  margin: 0 auto 0px;
}
.order__container {
  margin-bottom: 52px;
}
.order__box {
  padding: 29px 0;
  border-bottom: 1px solid #003161;
}
.order__box.mail {
  padding: 44px 0;
}
.order__boxInner {
  max-width: 820px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 56px 26px;
}
.order__left {
  width: 270px;
  min-width: 270px;
}
.order__right {
  width: fit-content;
}
.order__leftTxt {
  padding-left: 55px;
  font-size: 25px;
  font-weight: 700;
  position: relative;
}
.order__leftTxt.tel::before {
  display: block;
  content: "";
  width: 30px;
  height: 30px;
  background: url(../imgs/index/icon01.png) center center / cover no-repeat;
  position: absolute;
  top: 50%;
  left: 11px;
  transform: translate(0, -50%);
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
}
.order__leftTxt.fax::before {
  display: block;
  content: "";
  width: 30px;
  height: 30px;
  background: url(../imgs/index/icon02.png) center center / cover no-repeat;
  position: absolute;
  top: 50%;
  left: 11px;
  transform: translate(0, -50%);
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
}
.order__leftTxt.mail::before {
  display: block;
  content: "";
  width: 31px;
  height: 25px;
  background: url(../imgs/index/icon03.png) center center / cover no-repeat;
  position: absolute;
  top: 50%;
  left: 11px;
  transform: translate(0, -50%);
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
}
.order__rightTxt {
  margin-bottom: 3px;
  font-size: 30px;
  font-weight: 800;
}
.order__rightTxt02 {
  font-size: 19px;
  font-weight: 700;
}
.order__rightTxt03 {
  font-size: 20px;
  font-weight: 800;
  letter-spacing: 0.05em;
}
.order__pay {
  padding: 38px 80px 40px 83px;
  background: #003161;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 51px;
}
.order__payLeft {
  width: fit-content;
}
.order__payRight {
  flex: 1;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 75px;
  position: relative;
}
.order__payRight::before {
  display: block;
  content: "";
  width: 2px;
  height: 120px;
  background: url(../imgs/index/dashed-line.png) center center / cover no-repeat;
  position: absolute;
  top: 50%;
  left: 48.6%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}
.order__payBox {
  width: 50%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 20px;
}
.order__payTtl,
.order__payTtl02 {
  font-size: 25px;
  font-weight: 700;
  line-height: 1.6;
  color: #fff;
}

.order__payTxt {
  font-size: 19px;
  font-weight: 600;
  line-height: 1.4;
  color: #fff;
}
.order__payIcon {
  max-width: 100px;
}
.order__payGroup {
  flex: 1;
}
@media screen and (max-width: 1120px) {
  .order__pay {
    padding: 38px 47px 40px 47px;
    flex-direction: column;
  }
}
@media screen and (max-width: 750px) {
  .order {
    padding: 50px 0 50px;
  }
  .order__ttl {
    max-width: 320px;
  }
  .order__container {
    margin-bottom: 5px;
  }
  .order__box {
    padding: 9px 0 23px;
  }
  .order__box:first-child {
    padding-top: 0;
  }
  .order__box:last-child {
    border-bottom: none;
  }
  .order__box.mail {
    padding: 9px 0 23px;
  }
  .order__boxInner {
    flex-direction: column;
    row-gap: 10px;
  }
  .order__left {
    min-width: auto;
    width: 100%;
  }
  .order__leftTxt {
    padding-top: 53px;
    padding-left: 0;
    font-size: 17px;
    text-align: center;
  }
  .order__rightTxt {
    font-size: 25px;
  }
  .order__rightTxt02 {
    font-size: 14px;
    text-align: center;
  }
  .order__rightTxt03 {
    font-size: 20px;
  }
  .order__leftTxt.tel::before {
    position: absolute;
    top: 35%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
  }
  .order__leftTxt.fax::before {
    position: absolute;
    top: 35%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
  }
  .order__leftTxt.mail::before {
    position: absolute;
    top: 35%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
  }
  .order__pay {
    padding: 30px 15px 30px 24px;
    /* flex-direction: column;
    gap: 13px; */
    gap: 24px;
  }
  .order__payTtl {
    font-size: 23px;
  }
  .order__payTtl02 {
    font-size: 17px;
  }
  .order__payRight {
    width: 100%;
    flex-direction: column;
    gap: 44px;
  }
  .order__payRight::before {
    width: 100%;
    height: 2px;
    background: url(../imgs/index/dashed-line_sp.png) center center / cover repeat;
  }
  .order__payBox {
    width: 100%;
    gap: 11px;
  }
  .order__payIcon {
    max-width: 60px;
  }
  .order__payTxt {
    font-size: 15px;
  }
}

@media screen and (max-width: 440px) {
  .order__rightTxt03 {
    font-size: 4.5454vw;
  }
}

/*===================
onlineShop
===================*/
.onlineShop {
  width: 92%;
  max-width: 600px;
  margin: 0 auto 120px;
}
@media screen and (max-width: 750px) {
  .onlineShop {
    max-width: 320px;
    margin-bottom: 54px;
  }
}
