@charset "UTF-8";
/* ==========================================
  トップページ
 ============================================ */
/** -------------------- ページ内共通 -------------------- **/
.inner.inner--narrow {
  max-width: 1060px;
}

.dfk-top-h2 {
  text-align: center;
  font-size: 30px;
  line-height: 1;
  letter-spacing: 0.05em;
}

.dfk-top-ttl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px 16px;
  margin-bottom: 24px;
}
.dfk-top-ttl-eng {
  font-family: var(--font_roboto);
  font-size: 67px;
  font-weight: 300;
  line-height: 1;
}
.dfk-top-ttl-jp {
  line-height: 1;
  letter-spacing: 0.05em;
}

.is-yakuhan {
  letter-spacing: -0.45em;
}

.is-yakuhan-start {
  letter-spacing: -0.15em;
}

.is-yakuhan-end {
  letter-spacing: -0.45em;
}

header.dfk-header:not(.is-scroll) {
  background: none;
  -webkit-box-shadow: none;
          box-shadow: none;
}
header.dfk-header:not(.is-scroll) .dfk-header-logo {
  -webkit-filter: var(--filter_wht);
          filter: var(--filter_wht);
}
header.dfk-header:not(.is-scroll) .dfk-header-nav-link {
  color: var(--c_wht);
}
header.dfk-header:not(.is-scroll) .dfk-header-user-link {
  -webkit-filter: var(--filter_wht);
          filter: var(--filter_wht);
}
header.dfk-header:not(.is-scroll) .dfk-header-tel-link {
  opacity: 0;
  visibility: hidden;
}

.dfk-footer {
  margin-top: calc(-1 * var(--mask_height) - 1px);
}

/** -------------------- ファーストビュー -------------------- **/
.dfk-top-fv {
  position: relative;
}
.dfk-top-fv .dfk-top-fv-spacer {
  max-height: calc(90vh - var(--header_height));
}
.dfk-top-fv .dfk-top-fv-spacer:before {
  content: "";
  display: block;
  padding-top: calc(56.25% - var(--header_height) - 4dvw);
}
.dfk-top-fv .dfk-top-fv-video {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  padding-top: 56.25%;
  max-height: 100vh;
  z-index: -1;
  background: url(../../Contents/ImagesPkg/dogfoodkoubou2026/top/fv_video_thumb.jpg) no-repeat center/cover;
}
.dfk-top-fv .dfk-top-fv-video video, .dfk-top-fv .dfk-top-fv-video iframe {
  width: 100% !important;
  height: 100% !important;
  -o-object-fit: cover;
     object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
}
.dfk-top-fv .dfk-top-fv-sub {
  position: absolute;
  bottom: 145px;
  left: 0;
  width: 100%;
  z-index: 1;
}
.dfk-top-fv .dfk-top-fv-sub-item {
  position: absolute;
}
.dfk-top-fv .dfk-top-fv-sub-item01 {
  width: 345px;
  left: 85px;
  top: 0;
}
.dfk-top-fv .dfk-top-fv-sub-item02 {
  width: 115px;
  left: 457px;
  top: 140px;
}
.dfk-top-fv .dfk-top-fv-sub-item03 {
  width: 212px;
  top: 20px;
  right: 229px;
}
.dfk-top-fv .dfk-top-fv-sub-item04 {
  width: 191px;
  right: 19px;
  top: 87px;
}
.dfk-top-fv .dfk-top-fv-mask {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 20%;
  background: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/bg.jpg) repeat-y top center/100%;
  z-index: -1;
  display: none;
}

.dfk-top-fv.anim .dfk-top-fv-sub-item {
  opacity: 0;
  -webkit-transform: translateY(40px);
          transform: translateY(40px);
  -webkit-transition: all 0.7s ease-out;
  transition: all 0.7s ease-out;
}
.dfk-top-fv.anim .dfk-top-fv-sub-item02 {
  -webkit-transition-delay: 0.1s;
          transition-delay: 0.1s;
}
.dfk-top-fv.anim .dfk-top-fv-sub-item04 {
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
}
.dfk-top-fv.anim.is-show .dfk-top-fv-sub-item {
  opacity: 1;
  -webkit-transform: translateY(0);
          transform: translateY(0);
}

/** -------------------- 背景 -------------------- **/
.dfk-top-bg {
  background: -webkit-gradient(linear, left top, left bottom, from(rgba(255, 255, 255, 0)), color-stop(7dvw, rgba(255, 255, 255, 0)), color-stop(7dvw, rgb(255, 255, 255)), to(rgb(255, 255, 255)));
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 7dvw, rgb(255, 255, 255) 7dvw, rgb(255, 255, 255) 100%);
  padding: 0 0 120px;
}

.dfk-top-bg01 {
  background: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/bg.jpg) repeat-y top center/100%;
  -webkit-mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/top/bg_mask.svg), -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(6dvw, transparent), color-stop(6dvw, #000), to(#000));
  -webkit-mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/top/bg_mask.svg), linear-gradient(to bottom, transparent 0%, transparent 6dvw, #000 6dvw, #000 100%);
          mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/top/bg_mask.svg), -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(6dvw, transparent), color-stop(6dvw, #000), to(#000));
          mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/top/bg_mask.svg), linear-gradient(to bottom, transparent 0%, transparent 6dvw, #000 6dvw, #000 100%);
  -webkit-mask-size: 100%;
          mask-size: 100%;
  margin-top: -100px;
  position: relative;
  padding: 160px 0 40px;
}

.dfk-top-bg02 {
  background: var(--c_wht);
  position: relative;
}
.dfk-top-bg02:before {
  content: "";
  width: 100%;
  padding-top: 6.944%;
  background: url(../../Contents/ImagesPkg/dogfoodkoubou2026/top/bg_mask.svg) no-repeat center bottom/cover;
  position: absolute;
  bottom: 100%;
  left: 0;
}

.dfk-top-bg02-sub-item {
  position: absolute;
  z-index: 1;
}
.dfk-top-bg02-sub-item05 {
  width: 154px;
  left: 58px;
  bottom: calc(100% + 133px);
}
.dfk-top-bg02-sub-item06 {
  width: 290px;
  bottom: calc(100% - 13px);
  left: 154px;
  -webkit-transition-delay: 0.1s;
          transition-delay: 0.1s;
}
.dfk-top-bg02-sub-item07 {
  width: 244px;
  right: 274px;
  bottom: calc(100% + 10px);
}
.dfk-top-bg02-sub-item08 {
  width: 272px;
  right: 0;
  bottom: 100%;
  -webkit-transition-delay: 0.2s;
          transition-delay: 0.2s;
}

.dfk-top-bg03 {
  background: var(--c_bg_wht);
  -webkit-mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(transparent), color-stop(#000), to(#000));
  -webkit-mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), linear-gradient(to bottom, transparent 0%, transparent var(--mask_height), #000 var(--mask_height), #000 100%);
          mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(transparent), color-stop(#000), to(#000));
          mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), linear-gradient(to bottom, transparent 0%, transparent var(--mask_height), #000 var(--mask_height), #000 100%);
  -webkit-mask-size: var(--mask_width);
          mask-size: var(--mask_width);
  margin: calc(-1 * var(--mask_height)) 0 -80px;
  padding: 40px 0 100px;
}

.dfk-top-bg04 {
  background: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/bg.jpg) repeat-y top center/100%;
  border-radius: 50px 50px 0 0;
  padding: 100px 0;
  position: relative;
}

/** -------------------- ブランドストーリー -------------------- **/
.dfk-top-brand {
  padding: 110px 0 80px;
  position: relative;
  overflow: hidden;
}
.dfk-top-brand .dfk-top-brand-eng {
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
}
.dfk-top-brand .dfk-top-brand-txt {
  margin-top: 36px;
  font-size: 16px;
  line-height: 3.2;
  letter-spacing: 0.03em;
  text-align: center;
}
.dfk-top-brand .dfk-top-brand-more {
  margin-top: 74px;
  text-align: center;
}
.dfk-top-brand .dfk-top-brand-gallery-item {
  position: absolute;
  z-index: -1;
}
.dfk-top-brand .dfk-top-brand-gallery-item img {
  border-radius: 30px;
}
.dfk-top-brand .dfk-top-brand-gallery-item01 {
  top: 110px;
  right: calc(50% + 348px);
  width: 182px;
}
.dfk-top-brand .dfk-top-brand-gallery-item02 {
  top: 60px;
  left: calc(50% + 275px);
  width: 421px;
}
.dfk-top-brand .dfk-top-brand-gallery-item03 {
  bottom: 56px;
  right: calc(50% + 275px);
  width: 421px;
}
.dfk-top-brand .dfk-top-brand-gallery-item04 {
  bottom: 120px;
  left: calc(50% + 453px);
  width: 197px;
}

/** -------------------- こだわり -------------------- **/
.dfk-top-about {
  padding: 43px 0 132px;
  position: relative;
}
.dfk-top-about .dfk-top-about-eng {
  position: absolute;
  right: 0;
  top: -60px;
  z-index: -1;
}
.dfk-top-about .dfk-top-about-lead {
  text-align: center;
  margin-bottom: 24px;
  line-height: 1;
  letter-spacing: 0.05em;
}
.dfk-top-about .dfk-top-about-list {
  margin-top: 48px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 32px 1fr 32px 1fr 32px 1fr;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
}
.dfk-top-about .dfk-top-about-list-item {
  background: var(--c_wht);
  -webkit-box-shadow: 0px 0px 14px 4px rgba(0, 0, 0, 0.04);
          box-shadow: 0px 0px 14px 4px rgba(0, 0, 0, 0.04);
  padding: 16px 13px;
  display: -ms-grid;
  display: grid;
  -ms-grid-rows: subgrid;
  grid-template-rows: subgrid;
  -ms-grid-row-span: 2;
  grid-row: span 2;
  gap: 20px 0;
  border-radius: 20px;
}
.dfk-top-about .dfk-top-about-list-item-txt {
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
  text-align: center;
  font-size: 22px;
  line-height: 1.4;
}
.dfk-top-about .dfk-top-about-list-item-img img {
  border-radius: 20px;
}
.dfk-top-about .dfk-top-about-more {
  margin-top: 60px;
  text-align: center;
}

/** -------------------- 商品ラインアップ -------------------- **/
.dfk-top-lineup {
  padding: 50px 0;
  margin-bottom: 50px;
}
.dfk-top-lineup .dfk-top-lineup-list {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 20px 1fr 20px 1fr 20px 1fr;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.dfk-top-lineup .dfk-top-lineup-list-item-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  padding: 10px;
  border-radius: 20px;
  -webkit-box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.14);
          box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.14);
}
.dfk-top-lineup .dfk-top-lineup-list-item-link:hover {
  opacity: 1;
  color: var(--c_blue);
}
.dfk-top-lineup .dfk-top-lineup-list-item-link:hover .dfk-top-lineup-list-item-ttl {
  text-decoration-color: currentColor;
}
.dfk-top-lineup .dfk-top-lineup-list-item-img {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 134px;
          flex: 0 0 134px;
}
.dfk-top-lineup .dfk-top-lineup-list-item-img img {
  border-radius: 20px;
}
.dfk-top-lineup .dfk-top-lineup-list-item-ttl {
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: transparent;
  text-decoration-thickness: 1px;
  -webkit-transition: var(--anim);
  transition: var(--anim);
}
.dfk-top-lineup .dfk-top-lineup-more {
  margin-top: 50px;
  text-align: center;
}

/** -------------------- 開催中のキャンペーン -------------------- **/
.dfk-top-campaign {
  margin: -50px 0 100px;
}
.dfk-top-campaign .dfk-top-campaign-bnr {
  margin: 20px 0;
}
.dfk-top-campaign .dfk-top-campaign-bnr:last-child {
  margin-bottom: 0;
}

/** -------------------- 厳選食材 -------------------- **/
.dfk-top-ingredients {
  padding: 106px 0 48px;
  position: relative;
  overflow: hidden;
  color: #000;
}
.dfk-top-ingredients .dfk-top-ingredients-ttl {
  font-size: 24px;
  line-height: 1;
  margin-bottom: 24px;
}
.dfk-top-ingredients .dfk-top-ingredients-txt {
  font-size: 16px;
  line-height: 2.4;
  letter-spacing: 0.05em;
  margin: 24px 0;
}
.dfk-top-ingredients .dfk-top-ingredients-msg {
  max-width: 660px;
  background: rgba(255, 255, 255, 0.85);
  border-radius: 20px;
  padding: 35px 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 36px;
     -moz-column-gap: 36px;
          column-gap: 36px;
}
.dfk-top-ingredients .dfk-top-ingredients-msg-img {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 172px;
          flex: 0 0 172px;
}
.dfk-top-ingredients .dfk-top-ingredients-msg-ttl {
  font-size: 20px;
  line-height: 1.6;
  letter-spacing: 0.05em;
  margin-bottom: 8px;
}
.dfk-top-ingredients .dfk-top-ingredients-msg-txt {
  font-size: 16px;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
.dfk-top-ingredients .dfk-top-ingredients-eng {
  position: absolute;
  right: 0;
  top: -40px;
  z-index: -1;
}
.dfk-top-ingredients .dfk-top-ingredients-sub-item {
  position: absolute;
  right: 0;
  top: 65px;
  width: 590px;
  z-index: -1;
}
.dfk-top-ingredients .dfk-top-ingredients-more {
  margin-top: 32px;
  text-align: center;
}

/** -------------------- 生づくり製法 -------------------- **/
.dfk-top-method {
  padding: 48px 0 103px;
  color: #000;
  overflow: hidden;
  position: relative;
}
.dfk-top-method .dfk-top-method-eng {
  position: absolute;
  left: 0;
  bottom: 92px;
  z-index: -1;
}
.dfk-top-method .dfk-top-method-ttl {
  text-align: center;
  margin-bottom: 24px;
  font-size: 24px;
  line-height: 1.6;
}
.dfk-top-method .dfk-top-method-txt {
  text-align: center;
  margin-bottom: 24px;
  font-size: 16px;
  line-height: 2.4;
  letter-spacing: 0.05em;
}
.dfk-top-method .dfk-top-method-gallery {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  will-change: transform;
  -webkit-transform: translateZ(0);
          transform: translateZ(0);
}
.dfk-top-method .dfk-top-method-gallery-list {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-animation: slide2Left 40s linear infinite;
          animation: slide2Left 40s linear infinite;
}
.dfk-top-method .dfk-top-method-gallery-list > * {
  width: 420px;
}
.dfk-top-method .dfk-top-method-video {
  max-width: 750px;
  margin: 70px auto 42px;
}
.dfk-top-method .dfk-top-method-video-in {
  width: 100%;
  padding-top: 56.25%;
  position: relative;
}
.dfk-top-method .dfk-top-method-video-in video, .dfk-top-method .dfk-top-method-video-in iframe {
  width: 100% !important;
  height: 100% !important;
  position: absolute;
  top: 0;
  left: 0;
}
.dfk-top-method .dfk-top-method-more {
  margin-top: 42px;
  text-align: center;
}

@-webkit-keyframes slide2Left {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}

@keyframes slide2Left {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
/** -------------------- お試しセット・定期便　共通 -------------------- **/
.dfk-top-products {
  margin-bottom: 90px;
}
.dfk-top-products:nth-child(even) .dfk-top-products-container {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
.dfk-top-products:last-child {
  margin-bottom: 0;
}
.dfk-top-products .dfk-top-ttl {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
.dfk-top-products .dfk-top-products-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
}
.dfk-top-products .dfk-top-products-description {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 384px;
          flex: 0 0 384px;
  color: #000;
}
.dfk-top-products .dfk-top-products-lead {
  margin-top: 32px;
  font-size: 24px;
  line-height: normal;
}
.dfk-top-products .dfk-top-products-txt {
  font-size: 16px;
  line-height: 1.6;
  margin-top: 20px;
}
.dfk-top-products .dfk-top-products-more {
  margin-top: 40px;
}
/** -------------------- お試しセット -------------------- **/
.dfk-top-trial .dfk-top-trial-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
}
.dfk-top-trial .dfk-top-trial-list .item {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 250px;
          flex: 0 0 250px;
}
.dfk-top-trial .dfk-top-trial-list .link {
  display: block;
  width: 100%;
  height: 100%;
  background: var(--c_wht);
  border-radius: 20px;
  padding: 20px;
  -webkit-box-shadow: 0px 0px 14px 4px rgba(0, 0, 0, 0.04);
          box-shadow: 0px 0px 14px 4px rgba(0, 0, 0, 0.04);
}
.dfk-top-trial .dfk-top-trial-list .link:hover {
  opacity: 1;
}
.dfk-top-trial .dfk-top-trial-list .link:hover .name {
  text-decoration-color: currentColor;
}
.dfk-top-trial .dfk-top-trial-list .link.is-nolink {
  pointer-events: none;
}
.dfk-top-trial .dfk-top-trial-list .link.is-nolink .arrowbox {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.dfk-top-trial .dfk-top-trial-list .link.is-nolink .arrowbox:before, .dfk-top-trial .dfk-top-trial-list .link.is-nolink .arrowbox:after {
  display: none;
}
.dfk-top-trial .dfk-top-trial-list .link.is-nolink .price-item {
  text-align: center;
}
.dfk-top-trial .dfk-top-trial-list .img {
  width: 210px;
  max-width: 100%;
  margin: 0 auto 4px;
}
.dfk-top-trial .dfk-top-trial-list .name {
  text-align: center;
  font-size: 16px;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: transparent;
  text-decoration-thickness: 1px;
  -webkit-transition: var(--anim);
  transition: var(--anim);
}
.dfk-top-trial .dfk-top-trial-list .set {
  margin-top: 5px;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0.05em;
  text-align: center;
}
.dfk-top-trial .dfk-top-trial-list .arrowbox {
  margin-top: 17px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
}
.dfk-top-trial .dfk-top-trial-list .arrowbox:before {
  content: "";
  width: 55px;
  height: 55px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  background: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/chevron.png) no-repeat center/16px;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  -webkit-filter: var(--filter_wht);
          filter: var(--filter_wht);
}
.dfk-top-trial .dfk-top-trial-list .arrowbox:after {
  content: "";
  width: 55px;
  height: 55px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  background: var(--c_blue);
  border-radius: 50%;
}
.dfk-top-trial .dfk-top-trial-list .price-item--regular {
  font-size: 12px;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.05em;
  text-decoration: line-through;
}
.dfk-top-trial .dfk-top-trial-list .price-item--trial {
  font-size: 22px;
  line-height: normal;
}
.dfk-top-trial .dfk-top-trial-list .price-item--trial .num {
  font-family: var(--font_roboto);
  font-size: 30px;
  font-weight: 500;
}

/** -------------------- できたて定期便 -------------------- **/
.dfk-top-teiki .dfk-top-teiki-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
}
.dfk-top-teiki .dfk-top-teiki-list .item {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 250px;
          flex: 0 0 250px;
}
.dfk-top-teiki .dfk-top-teiki-list .link {
  display: block;
  width: 100%;
  height: 100%;
  background: var(--c_wht);
  border-radius: 20px;
  padding: 20px;
  -webkit-box-shadow: 0px 0px 14px 4px rgba(0, 0, 0, 0.04);
          box-shadow: 0px 0px 14px 4px rgba(0, 0, 0, 0.04);
}
.dfk-top-teiki .dfk-top-teiki-list .link:hover {
  opacity: 1;
}
.dfk-top-teiki .dfk-top-teiki-list .link:hover .name {
  text-decoration-color: currentColor;
}
.dfk-top-teiki .dfk-top-teiki-list .arrowbox {
  margin-top: 4px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  position: relative;
}
.dfk-top-teiki .dfk-top-teiki-list .arrowbox:before {
  content: "";
  width: 55px;
  height: 55px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  background: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/chevron.png) no-repeat center/16px;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
  -webkit-filter: var(--filter_wht);
          filter: var(--filter_wht);
}
.dfk-top-teiki .dfk-top-teiki-list .arrowbox:after {
  content: "";
  width: 55px;
  height: 55px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  background: var(--c_blue);
  border-radius: 50%;
}
.dfk-top-teiki .dfk-top-teiki-list .text {
  font-size: 14px;
  line-height: 1;
  letter-spacing: 0.05em;
  margin-bottom: 5px;
}
.dfk-top-teiki .dfk-top-teiki-list .name {
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.05em;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: transparent;
  text-decoration-thickness: 1px;
  -webkit-transition: var(--anim);
  transition: var(--anim);
}

/** -------------------- ランキング -------------------- **/
.dfk-top-ranking {
  padding: 100px 0;
}
.dfk-top-ranking .dfk-ranking-list-item:nth-child(n+6) {
  display: none;
}

/** -------------------- 商品を検索する -------------------- **/
.dfk-top-search {
  background: var(--c_bg_wht);
  -webkit-mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(transparent), color-stop(#000), to(#000));
  -webkit-mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), linear-gradient(to bottom, transparent 0%, transparent var(--mask_height), #000 var(--mask_height), #000 100%);
          mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(transparent), color-stop(#000), to(#000));
          mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), linear-gradient(to bottom, transparent 0%, transparent var(--mask_height), #000 var(--mask_height), #000 100%);
  -webkit-mask-size: var(--mask_width);
          mask-size: var(--mask_width);
  padding: 80px 0;
}
.dfk-top-search .dfk-top-search-ttl {
  margin: 40px 0 24px;
  font-size: 24px;
  line-height: normal;
}
.dfk-top-search .dfk-top-search-ttl:first-of-type {
  margin-top: 30px;
}
.dfk-top-search .dfk-top-search-meat {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 20px;
}
.dfk-top-search .dfk-top-search-meat-item {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 280px;
          flex: 0 0 280px;
}
.dfk-top-search .dfk-top-search-meat-item-link {
  display: block;
  position: relative;
  border-radius: 50%;
  overflow: hidden;
  color: var(--c_wht);
}
.dfk-top-search .dfk-top-search-meat-item-link:before {
  content: "";
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.15);
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  -webkit-transition: var(--anim);
  transition: var(--anim);
}
.dfk-top-search .dfk-top-search-meat-item-link:hover {
  opacity: 1;
}
.dfk-top-search .dfk-top-search-meat-item-link:hover:before {
  opacity: 1;
}
.dfk-top-search .dfk-top-search-meat-item-link:hover .dfk-top-search-meat-item-ttl {
  text-decoration-color: currentColor;
}
.dfk-top-search .dfk-top-search-meat-item-img {
  width: 100%;
}
.dfk-top-search .dfk-top-search-meat-item-img img {
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}
.dfk-top-search .dfk-top-search-meat-item-ttl {
  position: absolute;
  top: 50%;
  left: 0;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 100%;
  text-align: center;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: transparent;
  text-decoration-thickness: 1px;
  -webkit-transition: var(--anim);
  transition: var(--anim);
}
.dfk-top-search .dfk-top-search-trouble {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 30px 1fr 30px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px 30px;
}
.dfk-top-search .dfk-top-search-trouble-item-link {
  text-align: center;
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: var(--c_wht);
  border: 1px solid var(--c_blue);
  border-radius: 10px;
  font-size: 20px;
  line-height: 1;
  padding: 25px;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: transparent;
  text-decoration-thickness: 1px;
}
.dfk-top-search .dfk-top-search-trouble-item-link:hover {
  opacity: 1;
  text-decoration-color: currentColor;
}

/** -------------------- バナーエリア -------------------- **/
.dfk-top-bnrarea {
  padding: 80px 0;
}
.dfk-top-bnrarea .dfk-top-bnrarea-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 40px;
}
.dfk-top-bnrarea .dfk-top-bnrarea-list-item {
  -webkit-box-flex: 0;
      -ms-flex: 0 1 calc((100% - 40px) / 2);
          flex: 0 1 calc((100% - 40px) / 2);
}
.dfk-top-bnrarea .dfk-top-bnrarea-list-item-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 12px;
     -moz-column-gap: 12px;
          column-gap: 12px;
  border: 2px solid var(--c_blue);
  border-radius: 20px;
}
.dfk-top-bnrarea .dfk-top-bnrarea-list-item-link .img {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 246px;
          flex: 0 0 246px;
}
.dfk-top-bnrarea .dfk-top-bnrarea-list-item-link .text {
  line-height: 1;
  letter-spacing: 0.05em;
  margin-bottom: 10px;
}
.dfk-top-bnrarea .dfk-top-bnrarea-list-item-link .title {
  font-size: 24px;
  line-height: normal;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: transparent;
  text-decoration-thickness: 1px;
  -webkit-transition: var(--anim);
  transition: var(--anim);
}
.dfk-top-bnrarea .dfk-top-bnrarea-list-item-link .title .logo {
  border-bottom: 1px solid transparent;
  -webkit-transition: var(--anim);
  transition: var(--anim);
}
.dfk-top-bnrarea .dfk-top-bnrarea-list-item-link:hover {
  opacity: 1;
}
.dfk-top-bnrarea .dfk-top-bnrarea-list-item-link:hover .title {
  text-decoration-color: currentColor;
}
.dfk-top-bnrarea .dfk-top-bnrarea-list-item-link:hover .title .logo {
  border-color: var(--c_blue);
}

/** -------------------- お客様と愛犬のストーリー -------------------- **/
.dfk-top-story {
  background: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/bg.jpg) repeat-y top center/100%;
  -webkit-mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(transparent), color-stop(#000), to(#000));
  -webkit-mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), linear-gradient(to bottom, transparent 0%, transparent var(--mask_height), #000 var(--mask_height), #000 100%);
          mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(transparent), color-stop(#000), to(#000));
          mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), linear-gradient(to bottom, transparent 0%, transparent var(--mask_height), #000 var(--mask_height), #000 100%);
  -webkit-mask-size: var(--mask_width);
          mask-size: var(--mask_width);
  padding: 100px 0;
  position: relative;
}
.dfk-top-story .dfk-top-story-eng {
  position: absolute;
  top: 22px;
  left: 0;
  z-index: -1;
}
.dfk-top-story .dfk-top-story-slider {
  margin-top: 50px;
}
.dfk-top-story .dfk-top-story-slider-item {
  width: 1060px;
  max-width: 100%;
  height: auto;
}
.dfk-top-story .dfk-top-story-slider-item-link {
  background: var(--c_wht);
  -webkit-box-shadow: 0px 0px 14px 4px rgba(0, 0, 0, 0.04);
          box-shadow: 0px 0px 14px 4px rgba(0, 0, 0, 0.04);
  border-radius: 50px;
  padding: 56px 64px;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.dfk-top-story .dfk-top-story-slider-item-link .img {
  -webkit-box-flex: 0;
      -ms-flex: 0 1 269px;
          flex: 0 1 269px;
}
.dfk-top-story .dfk-top-story-slider-item-link .img img {
  aspect-ratio: 269/344;
  -o-object-fit: cover;
     object-fit: cover;
}
.dfk-top-story .dfk-top-story-slider-item-link .txtbox {
  -webkit-box-flex: 0;
      -ms-flex: 0 1 610px;
          flex: 0 1 610px;
  color: #000;
}
.dfk-top-story .dfk-top-story-slider-item-link .title {
  font-size: 24px;
  line-height: normal;
  margin-bottom: 20px;
}
.dfk-top-story .dfk-top-story-slider-item-link .profile {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4px 11px;
  margin-bottom: 20px;
  font-size: 14px;
  line-height: 1.6;
}
.dfk-top-story .dfk-top-story-slider-item-link .type {
  font-size: 12px;
  line-height: 1.6;
  padding: 0 8px;
  border: 1px solid currentColor;
  border-radius: 100px;
}
.dfk-top-story .dfk-top-story-slider-item-link .text {
  font-size: 16px;
  line-height: 1.6;
}
.dfk-top-story .dfk-top-story-slider-arrow {
  width: 55px;
  height: 55px;
  background: var(--c_wht);
  border: 1px solid var(--c_blue);
  border-radius: 50%;
  left: calc(50% + 502px);
}
.dfk-top-story .dfk-top-story-slider-arrow:before {
  content: "";
  width: 16px;
  height: 16px;
  background: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/chevron.png) no-repeat center/contain;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  -webkit-filter: var(--filter_blue);
          filter: var(--filter_blue);
}
.dfk-top-story .dfk-top-story-slider-arrow:after {
  display: none;
}
.dfk-top-story .dfk-top-story-slider-arrow.swiper-button-prev {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
  left: auto;
  right: calc(50% + 502px);
}
.dfk-top-story .dfk-top-story-more {
  margin-top: 40px;
  text-align: center;
}

/** -------------------- SNSで話題の投稿を見る -------------------- **/
.dfk-top-sns {
  background: var(--c_wht);
  -webkit-mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(transparent), color-stop(#000), to(#000));
  -webkit-mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), linear-gradient(to bottom, transparent 0%, transparent var(--mask_height), #000 var(--mask_height), #000 100%);
          mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(transparent), color-stop(#000), to(#000));
          mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), linear-gradient(to bottom, transparent 0%, transparent var(--mask_height), #000 var(--mask_height), #000 100%);
  -webkit-mask-size: var(--mask_width);
          mask-size: var(--mask_width);
  margin-top: calc(-1 * var(--mask_height));
  padding: 100px 0;
  position: relative;
}
.dfk-top-sns .dfk-top-sns-eng {
  position: absolute;
  top: 22px;
  right: 0;
  z-index: -1;
}
.dfk-top-sns .dfk-top-sns-list {
  margin-top: 55px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 26px 1fr 26px 1fr 26px 1fr;
  grid-template-columns: repeat(4, 1fr);
  gap: 26px;
}
.dfk-top-sns .dfk-top-sns-list-item-link {
  position: relative;
  display: block;
  border-radius: 20px;
  overflow: hidden;
  -webkit-box-shadow: 0px 0px 14px 4px rgba(0, 0, 0, 0.04);
          box-shadow: 0px 0px 14px 4px rgba(0, 0, 0, 0.04);
}
.dfk-top-sns .dfk-top-sns-list-item-link img {
  width: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}
.dfk-top-sns .dfk-top-sns-list-item-link:before {
  content: "投稿を見る";
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.05em;
  background: rgba(0, 0, 0, 0.4);
  color: var(--c_wht);
  position: absolute;
  top: 0;
  left: 0;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  -webkit-transition: var(--anim);
  transition: var(--anim);
  opacity: 0;
}
.dfk-top-sns .dfk-top-sns-list-item-link:hover {
  opacity: 1;
}
.dfk-top-sns .dfk-top-sns-list-item-link:hover:before {
  opacity: 1;
}

/** -------------------- 新着情報 -------------------- **/
.dfk-top-news {
  background: var(--c_bg_wht);
  -webkit-mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(transparent), color-stop(#000), to(#000));
  -webkit-mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), linear-gradient(to bottom, transparent 0%, transparent var(--mask_height), #000 var(--mask_height), #000 100%);
          mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), -webkit-gradient(linear, left top, left bottom, from(transparent), color-stop(transparent), color-stop(#000), to(#000));
          mask-image: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/wave_mask.svg), linear-gradient(to bottom, transparent 0%, transparent var(--mask_height), #000 var(--mask_height), #000 100%);
  -webkit-mask-size: var(--mask_width);
          mask-size: var(--mask_width);
  padding: 100px 0 140px;
  position: relative;
}
.dfk-top-news .dfk-top-news-box {
  background: var(--c_wht);
  padding: 60px 70px;
  border-radius: 50px;
}
.dfk-top-news .dfk-news {
  margin-top: 34px;
}
.dfk-top-news .dfk-top-news-bnr {
  margin-top: 80px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 40px;
}
.dfk-top-news .dfk-top-news-bnr-item {
  -webkit-box-flex: 0;
      -ms-flex: 0 1 calc((100% - 40px) / 2);
          flex: 0 1 calc((100% - 40px) / 2);
}
.dfk-top-news .dfk-top-news-bnr-item-link {
  display: block;
  border-radius: 20px;
  overflow: hidden;
  -webkit-box-shadow: 0px 0px 14px 4px rgba(0, 0, 0, 0.04);
          box-shadow: 0px 0px 14px 4px rgba(0, 0, 0, 0.04);
}

/** -------------------- お役立ちコラム -------------------- **/
.dfk-top-column {
  background: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/bg.jpg) repeat-y top center/100%;
  border-radius: 50px 50px 0 0;
  padding: 115px 0 100px;
  margin-top: -40px;
  position: relative;
  z-index: 1;
}
.dfk-top-column .dfk-top-column-eng {
  position: absolute;
  top: 0;
  left: calc(50% + 58px);
  z-index: -1;
}
.dfk-top-column .dfk-top-column-slider {
  margin-top: 55px;
}
.dfk-top-column .dfk-top-column-slider .link:hover {
  opacity: 1;
}
.dfk-top-column .dfk-top-column-slider .link:hover .img img {
  opacity: 0.7;
}
.dfk-top-column .dfk-top-column-slider .link:hover .title {
  text-decoration-color: currentColor;
}
.dfk-top-column .dfk-top-column-slider .img {
  border-radius: 20px;
  overflow: hidden;
  margin-bottom: 20px;
}
.dfk-top-column .dfk-top-column-slider .img img {
  -webkit-transition: var(--anim);
  transition: var(--anim);
}
.dfk-top-column .dfk-top-column-slider .title {
  font-size: 16px;
  line-height: 1.6;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-color: transparent;
  text-decoration-thickness: 1px;
  -webkit-transition: var(--anim);
  transition: var(--anim);
}
.dfk-top-column .dfk-top-column-more {
  margin-top: 50px;
  text-align: center;
}

/** -------------------- 工房だより -------------------- **/
.dfk-top-magazine {
  padding: 80px 0;
  position: relative;
  z-index: 1;
}
.dfk-top-magazine:last-child {
  padding-bottom: 0;
}
.dfk-top-magazine .dfk-top-magazine-eng {
  position: absolute;
  top: 0;
  right: calc(50% + 53px);
  z-index: -1;
}
.dfk-top-magazine .dfk-top-magazine-container {
  margin-top: 48px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.dfk-top-magazine .dfk-top-magazine-img {
  -webkit-box-flex: 0;
      -ms-flex: 0 1 428px;
          flex: 0 1 428px;
}
.dfk-top-magazine .dfk-top-magazine-txtbox {
  -webkit-box-flex: 0;
      -ms-flex: 0 1 510px;
          flex: 0 1 510px;
}
.dfk-top-magazine .dfk-top-magazine-ttl {
  margin-bottom: 20px;
  font-size: 24px;
  line-height: normal;
}
.dfk-top-magazine .dfk-top-magazine-txt {
  font-size: 16px;
  line-height: 1.6;
  margin-bottom: 38px;
}
.dfk-top-magazine .dfk-top-magazine-list .item {
  margin-bottom: 10px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
}
.dfk-top-magazine .dfk-top-magazine-list .item:last-child {
  margin-bottom: 0;
}
.dfk-top-magazine .dfk-top-magazine-list .link {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 10px;
     -moz-column-gap: 10px;
          column-gap: 10px;
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-color: transparent;
  text-decoration-thickness: 1px;
}
.dfk-top-magazine .dfk-top-magazine-list .link:after {
  content: "";
  width: 10px;
  height: 10px;
  background: url(../../Contents/ImagesPkg/dogfoodkoubou2026/common/chevron.png) no-repeat center/contain;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -webkit-filter: var(--filter_text);
          filter: var(--filter_text);
}
.dfk-top-magazine .dfk-top-magazine-list .link:hover {
  opacity: 1;
  text-decoration-color: currentColor;
}
.dfk-top-magazine .dfk-top-magazine-more {
  margin-top: 39px;
}

/** -------------------- メディア紹介 -------------------- **/
.dfk-top-media .dfk-top-media-container {
  background: var(--c_bg_wht);
  border-radius: 50px;
  padding: 30px 70px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-column-gap: 16px;
     -moz-column-gap: 16px;
          column-gap: 16px;
}
.dfk-top-media .dfk-top-media-ttl {
  font-size: 16px;
  line-height: 1.4;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
.dfk-top-media .dfk-top-media-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 8px 16px;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.4;
}
.dfk-top-media .dfk-top-media-list .link {
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
}

/* スマホ
  ------------------------ */
@media (max-width: 768px) {
  /** -------------------- ページ内共通 -------------------- **/
  .dfk-top-h2 {
    font-size: 20px;
  }
  .dfk-top-ttl {
    gap: 0 10px;
    margin-bottom: 20px;
  }
  .dfk-top-ttl-eng {
    font-size: 34px;
  }
  .dfk-top-ttl-jp {
    font-size: 14px;
  }
  /** -------------------- ファーストビュー -------------------- **/
  .dfk-top-fv .dfk-top-fv-spacer:before {
    padding-top: calc(603px - var(--header_height) - 7dvw);
  }
  .dfk-top-fv .dfk-top-fv-video {
    padding-top: 177.78%;
    background: url(../../Contents/ImagesPkg/dogfoodkoubou2026/top/fv_video_thumb_sp.jpg) no-repeat center/cover;
  }
  .dfk-top-fv .dfk-top-fv-sub {
    bottom: 25px;
  }
  .dfk-top-fv .dfk-top-fv-sub-item01 {
    width: 155px;
    left: 7px;
  }
  .dfk-top-fv .dfk-top-fv-sub-item02 {
    width: 55px;
    left: 160px;
    top: 67px;
  }
  .dfk-top-fv .dfk-top-fv-sub-item03 {
    width: 81px;
    top: 9px;
    right: 62px;
  }
  .dfk-top-fv .dfk-top-fv-sub-item04 {
    width: 72px;
    right: 0;
    top: 36px;
  }
  .dfk-top-fv.anim .dfk-top-fv-sub-item {
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  /** -------------------- 背景 -------------------- **/
  .dfk-top-bg {
    padding-bottom: 80px;
  }
  .dfk-top-bg01 {
    margin-top: 0;
    padding: 72px 0 50px;
  }
  .dfk-top-bg02-sub-item05 {
    width: 69px;
    left: 10px;
    bottom: calc(100% + 28px);
  }
  .dfk-top-bg02-sub-item06 {
    width: 129px;
    left: 20px;
    bottom: calc(100% - 36px);
  }
  .dfk-top-bg02-sub-item07 {
    width: 113px;
    right: 68px;
    bottom: calc(100% - 40px);
  }
  .dfk-top-bg02-sub-item08 {
    width: 95px;
  }
  .dfk-top-bg03 {
    padding-bottom: 50px;
    margin-bottom: -50px;
  }
  .dfk-top-bg04 {
    border-radius: 30px 30px 0 0;
    padding: 50px 0;
  }
  /** -------------------- ブランドストーリー -------------------- **/
  .dfk-top-brand {
    padding: 57px 0 35px;
  }
  .dfk-top-brand .dfk-top-brand-eng {
    left: -3px;
  }
  .dfk-top-brand .dfk-top-brand-txt {
    margin-top: 20px;
    font-size: 14px;
    line-height: 2.5;
  }
  .dfk-top-brand .dfk-top-brand-more {
    margin-top: 27px;
  }
  .dfk-top-brand .dfk-top-brand-gallery {
    display: -ms-grid;
    display: grid;
    -ms-grid-columns: (minmax(auto, 174px))[2];
    grid-template-columns: repeat(2, minmax(auto, 174px));
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 0 10px;
    margin-top: 20px;
  }
  .dfk-top-brand .dfk-top-brand-gallery-item {
    position: relative;
    top: auto !important;
    bottom: auto !important;
    right: auto !important;
    left: auto !important;
    z-index: auto;
    margin: 0 auto;
  }
  .dfk-top-brand .dfk-top-brand-gallery-item img {
    border-radius: 20px;
  }
  .dfk-top-brand .dfk-top-brand-gallery-item01 {
    width: 106px;
  }
  .dfk-top-brand .dfk-top-brand-gallery-item02 {
    width: 171px;
  }
  .dfk-top-brand .dfk-top-brand-gallery-item03 {
    width: 100%;
  }
  .dfk-top-brand .dfk-top-brand-gallery-item04 {
    width: 113px;
  }
  /** -------------------- こだわり -------------------- **/
  .dfk-top-about {
    padding: 60px 0 50px;
  }
  .dfk-top-about .dfk-top-about-eng {
    top: 0;
  }
  .dfk-top-about .dfk-top-about-lead {
    margin-bottom: 12px;
    font-size: 14px;
    line-height: 1.3;
  }
  .dfk-top-about .dfk-top-about-list {
    margin-top: 20px;
    -ms-grid-columns: 1fr 15px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
  }
  .dfk-top-about .dfk-top-about-list-item {
    padding: 10px;
    gap: 11px 0;
  }
  .dfk-top-about .dfk-top-about-list-item-txt {
    font-size: 15px;
  }
  .dfk-top-about .dfk-top-about-list-item-img img {
    border-radius: 10px;
  }
  .dfk-top-about .dfk-top-about-more {
    margin-top: 27px;
  }
  /** -------------------- 商品ラインアップ -------------------- **/
  .dfk-top-lineup .dfk-top-lineup-list {
    -ms-grid-columns: 1fr 15px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px 15px;
  }
  .dfk-top-lineup .dfk-top-lineup-list-item-link {
    border-radius: 10px;
    padding: 5px;
  }
  .dfk-top-lineup .dfk-top-lineup-list-item-img {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 60px;
            flex: 0 0 60px;
  }
  .dfk-top-lineup .dfk-top-lineup-list-item-img img {
    border-radius: 10px;
  }
  .dfk-top-lineup .dfk-top-lineup-list-item-ttl {
    font-size: 14px;
  }
  .dfk-top-lineup .dfk-top-lineup-more {
    margin-top: 21px;
  }
  /** -------------------- 開催中のキャンペーン -------------------- **/
  .dfk-top-campaign {
    margin: -50px 0 50px;
  }
  .dfk-top-campaign .dfk-top-campaign-bnr {
    margin: 10px 0;
  }
  /** -------------------- 厳選食材 -------------------- **/
  .dfk-top-ingredients {
    padding: 50px 0 20px;
  }
  .dfk-top-ingredients .dfk-top-ingredients-ttl {
    font-size: 18px;
    line-height: 1.3;
    margin-bottom: 17px;
    text-align: center;
  }
  .dfk-top-ingredients .dfk-top-ingredients-txt {
    font-size: 14px;
    line-height: 2;
    margin: 17px 0 16px;
  }
  .dfk-top-ingredients .dfk-top-ingredients-msg {
    max-width: none;
    padding: 25px 20px;
    display: block;
  }
  .dfk-top-ingredients .dfk-top-ingredients-msg-img {
    width: 144px;
    margin: 0 auto 16px;
  }
  .dfk-top-ingredients .dfk-top-ingredients-msg-ttl {
    font-size: 16px;
    margin-bottom: 8px;
    text-align: center;
  }
  .dfk-top-ingredients .dfk-top-ingredients-msg-txt {
    font-size: 14px;
    line-height: 1.6;
  }
  .dfk-top-ingredients .dfk-top-ingredients-sub {
    position: relative;
    margin-top: 14px;
  }
  .dfk-top-ingredients .dfk-top-ingredients-eng {
    width: 331px;
    right: 0;
    top: -66px;
    z-index: 1;
  }
  .dfk-top-ingredients .dfk-top-ingredients-sub-item {
    position: relative;
    right: auto;
    top: auto;
    width: 100%;
    max-width: 335px;
    margin: 0 auto;
    z-index: 2;
  }
  .dfk-top-ingredients .dfk-top-ingredients-more {
    margin-top: 11px;
  }
  /** -------------------- 生づくり製法 -------------------- **/
  .dfk-top-method {
    padding: 20px 0 50px;
  }
  .dfk-top-method .dfk-top-method-eng {
    width: 426px;
    bottom: 83px;
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
  .dfk-top-method .dfk-top-method-ttl {
    font-size: 18px;
    line-height: 1.6;
    margin-bottom: 17px;
  }
  .dfk-top-method .dfk-top-method-txt {
    font-size: 14px;
    line-height: 2;
    margin-bottom: 20px;
    text-align: left;
  }
  .dfk-top-method .dfk-top-method-gallery-list > * {
    width: 154px;
  }
  .dfk-top-method .dfk-top-method-video {
    margin: 30px auto 47px;
  }
  .dfk-top-method .dfk-top-method-more {
    margin-top: 47px;
  }
  /** -------------------- お試しセット・定期便　共通 -------------------- **/
  .dfk-top-products {
    margin-bottom: 40px;
  }
  .dfk-top-products .dfk-top-ttl {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .dfk-top-products .dfk-top-products-container {
    display: block;
  }
  .dfk-top-products .dfk-top-products-description {
    margin-bottom: 20px;
  }
  .dfk-top-products .dfk-top-products-lead {
    margin-top: 24px;
    font-size: 18px;
  }
  .dfk-top-products .dfk-top-products-txt {
    margin-top: 16px;
    font-size: 14px;
  }
  .dfk-top-products .dfk-top-products-more {
    margin-top: 29px;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
  .dfk-top-products .dfk-top-products-scroll {
    overflow-y: hidden;
    overflow-x: auto;
    margin: -14px -20px 0;
    padding: 14px 20px;
  }
  /** -------------------- お試しセット -------------------- **/
  .dfk-top-trial .dfk-top-trial-list {
    gap: 20px;
  }
  .dfk-top-trial .dfk-top-trial-list:after {
    content: "";
    width: 20px;
    margin-left: -20px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .dfk-top-trial .dfk-top-trial-list .item {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 200px;
            flex: 0 0 200px;
  }
  .dfk-top-trial .dfk-top-trial-list .link {
    padding: 20px;
  }
  .dfk-top-trial .dfk-top-trial-list .img {
    width: 160px;
    margin-bottom: 6px;
  }
  .dfk-top-trial .dfk-top-trial-list .name {
    font-size: 14px;
    margin: 0 -10px;
  }
  .dfk-top-trial .dfk-top-trial-list .set {
    margin-top: 6px;
    font-size: 10px;
  }
  .dfk-top-trial .dfk-top-trial-list .arrowbox {
    margin-top: 16px;
  }
  .dfk-top-trial .dfk-top-trial-list .arrowbox:before, .dfk-top-trial .dfk-top-trial-list .arrowbox:after {
    width: 40px;
    height: 40px;
  }
  .dfk-top-trial .dfk-top-trial-list .arrowbox:before {
    background-size: 12px;
  }
  .dfk-top-trial .dfk-top-trial-list .price-item--regular {
    font-size: 10px;
    margin-bottom: 3px;
  }
  .dfk-top-trial .dfk-top-trial-list .price-item--trial {
    font-size: 16px;
  }
  .dfk-top-trial .dfk-top-trial-list .price-item--trial .num {
    font-size: 24px;
  }
  /** -------------------- できたて定期便 -------------------- **/
  .dfk-top-teiki .dfk-top-teiki-list:after {
    content: "";
    width: 4px;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
  .dfk-top-teiki .dfk-top-teiki-list .item {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 210px;
            flex: 0 0 210px;
  }
  .dfk-top-teiki .dfk-top-teiki-list .link {
    padding: 24px 15px;
  }
  .dfk-top-teiki .dfk-top-teiki-list .arrowbox {
    margin-top: 20px;
  }
  .dfk-top-teiki .dfk-top-teiki-list .arrowbox:before, .dfk-top-teiki .dfk-top-teiki-list .arrowbox:after {
    width: 40px;
    height: 40px;
  }
  .dfk-top-teiki .dfk-top-teiki-list .arrowbox:before {
    background-size: 12px;
  }
  .dfk-top-teiki .dfk-top-teiki-list .text {
    font-size: 13px;
  }
  /** -------------------- ランキング -------------------- **/
  .dfk-top-ranking {
    padding: 50px 0 36px;
  }
  /** -------------------- 商品を検索する -------------------- **/
  .dfk-top-search {
    padding: 50px 0;
  }
  .dfk-top-search .dfk-top-search-ttl {
    font-size: 18px;
  }
  .dfk-top-search .dfk-top-search-ttl:first-of-type {
    margin-top: 24px;
  }
  .dfk-top-search .dfk-top-search-meat {
    gap: 17px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .dfk-top-search .dfk-top-search-meat-item {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 100px;
            flex: 0 1 100px;
  }
  .dfk-top-search .dfk-top-search-trouble {
    -ms-grid-columns: 1fr 15px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px 15px;
  }
  .dfk-top-search .dfk-top-search-trouble-item-link {
    font-size: 16px;
    padding: 16px 8px;
  }
  /** -------------------- バナーエリア -------------------- **/
  .dfk-top-bnrarea {
    padding: 50px 0;
  }
  .dfk-top-bnrarea .dfk-top-bnrarea-list {
    gap: 10px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .dfk-top-bnrarea .dfk-top-bnrarea-list-item {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 335px;
            flex: 0 1 335px;
  }
  .dfk-top-bnrarea .dfk-top-bnrarea-list-item-link {
    -webkit-column-gap: 8px;
       -moz-column-gap: 8px;
            column-gap: 8px;
    border-radius: 10px;
  }
  .dfk-top-bnrarea .dfk-top-bnrarea-list-item-link .img {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 126px;
            flex: 0 0 126px;
  }
  .dfk-top-bnrarea .dfk-top-bnrarea-list-item-link .text {
    font-size: 12px;
    margin-bottom: 3px;
  }
  .dfk-top-bnrarea .dfk-top-bnrarea-list-item-link .title {
    font-size: 16px;
  }
  /** -------------------- お客様と愛犬のストーリー -------------------- **/
  .dfk-top-story {
    padding: 50px 0;
  }
  .dfk-top-story .dfk-top-story-eng {
    top: 4px;
    left: 0;
  }
  .dfk-top-story .dfk-top-story-slider {
    margin-top: 28px;
    padding: 0 20px;
  }
  .dfk-top-story .dfk-top-story-slider-item {
    width: auto;
  }
  .dfk-top-story .dfk-top-story-slider-item-link {
    padding: 25px 35px;
    border-radius: 30px;
    display: block;
  }
  .dfk-top-story .dfk-top-story-slider-item-link .img {
    margin-bottom: 16px;
  }
  .dfk-top-story .dfk-top-story-slider-item-link .img img {
    aspect-ratio: 265/229;
    margin: 0 auto;
  }
  .dfk-top-story .dfk-top-story-slider-item-link .title {
    font-size: 18px;
    margin-bottom: 10px;
  }
  .dfk-top-story .dfk-top-story-slider-item-link .profile {
    margin-bottom: 10px;
    font-size: 12px;
  }
  .dfk-top-story .dfk-top-story-slider-item-link .type {
    font-size: 10px;
  }
  .dfk-top-story .dfk-top-story-slider-item-link .text {
    font-size: 14px;
  }
  .dfk-top-story .dfk-top-story-slider-arrow {
    width: 30px;
    height: 30px;
    left: auto;
    right: 5px;
  }
  .dfk-top-story .dfk-top-story-slider-arrow:before {
    width: 10px;
    height: 10px;
  }
  .dfk-top-story .dfk-top-story-slider-arrow.swiper-button-prev {
    right: auto;
    left: 5px;
  }
  .dfk-top-story .dfk-top-story-more {
    margin-top: 25px;
    text-align: left;
  }
  /** -------------------- SNSで話題の投稿を見る -------------------- **/
  .dfk-top-sns {
    padding: 50px 0;
  }
  .dfk-top-sns .dfk-top-sns-eng {
    top: -10px;
  }
  .dfk-top-sns .dfk-top-sns-list {
    margin-top: 16px;
    -ms-grid-columns: 1fr 15px 1fr;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
  }
  .dfk-top-sns .dfk-top-sns-list-item-link:before {
    font-size: 14px;
  }
  /** -------------------- 新着情報 -------------------- **/
  .dfk-top-news {
    padding: 50px 0 90px;
  }
  .dfk-top-news .dfk-top-news-box {
    padding: 25px 10px 25px 30px;
    border-radius: 30px;
  }
  .dfk-top-news .dfk-news {
    margin-top: 20px;
  }
  .dfk-top-news .dfk-top-news-bnr {
    margin-top: 24px;
    gap: 16px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .dfk-top-news .dfk-top-news-bnr-item {
    -webkit-box-flex: 0;
        -ms-flex: 0 1 335px;
            flex: 0 1 335px;
  }
  /** -------------------- お役立ちコラム -------------------- **/
  .dfk-top-column {
    padding: 60px 0 50px;
    border-radius: 30px 30px 0 0;
  }
  .dfk-top-column .dfk-top-column-eng {
    top: 10px;
    left: auto;
    right: 17px;
  }
  .dfk-top-column .dfk-top-column-slider {
    margin: 24px -20px 0;
  }
  .dfk-top-column .dfk-top-column-slider .item {
    width: 250px;
  }
  .dfk-top-column .dfk-top-column-slider .img {
    margin-bottom: 12px;
  }
  .dfk-top-column .dfk-top-column-slider .title {
    font-size: 14px;
  }
  .dfk-top-column .dfk-top-column-more {
    margin-top: 32px;
  }
  /** -------------------- 工房だより -------------------- **/
  .dfk-top-magazine {
    padding: 60px 0;
  }
  .dfk-top-magazine .dfk-top-magazine-eng {
    top: -7px;
    right: auto;
    left: 0;
  }
  .dfk-top-magazine .dfk-top-magazine-container {
    margin-top: 30px;
    display: block;
  }
  .dfk-top-magazine .dfk-top-magazine-img {
    width: 250px;
    margin: 0 auto 30px;
  }
  .dfk-top-magazine .dfk-top-magazine-ttl {
    font-size: 18px;
  }
  .dfk-top-magazine .dfk-top-magazine-txt {
    font-size: 14px;
    margin-bottom: 20px;
  }
  .dfk-top-magazine .dfk-top-magazine-list .item {
    margin-bottom: 18px;
    font-size: 14px;
  }
  .dfk-top-magazine .dfk-top-magazine-list .link:after {
    width: 8px;
    height: 8px;
  }
  .dfk-top-magazine .dfk-top-magazine-more {
    margin-top: 30px;
  }
  /** -------------------- メディア紹介 -------------------- **/
  .dfk-top-media .dfk-top-media-container {
    padding: 10px 13px;
    gap: 4px 8px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .dfk-top-media .dfk-top-media-ttl {
    font-size: 14px;
  }
  .dfk-top-media .dfk-top-media-list {
    gap: 4px 8px;
    font-size: 12px;
  }
}