@charset "UTF-8";

/**********************************************************
 *
 * SMTパーツ
 *
 **********************************************************/

/* Main Visual */
.mv{
  position: relative;
}
.mv img{
  width: 100%;
  height: auto;
}
.mv .mv-fig{
  margin-bottom: 0;
}
.mv .mv-fig-img{}
.mv .mv-title{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.mv .mv-title-fig{
  width: 69.444%;
}
.mv .mv-title-img{}


/* FV */
.fv{
  background-color: #fff;
  width: 100%;
  overflow-x: hidden;
}
.fv img{
  width: 100%;
  height: auto;
}
.fv .fv-inner{
  background-image: linear-gradient(
    to bottom,
    #fff5d7,
    #f7e9d8 26%,
    #ffe9ea 56%,
    #fff5d7 80%,
    #ffffff
  );
  padding-top: 16.944vw;
}
.fv .fv-cnt{
  margin-bottom: 19.444vw;
}
.fv .fv-logo{
  background-color: #fff;
  border-radius: 50%;
  box-shadow: 0px 0px 5px 5px rgba(0, 0, 0, 0.1);
  padding: 8px;
  margin-right: auto;
  margin-left: auto;
  width: 66.667%;
  max-width: 240px;
}
.fv .fv-logo-img{}

.fv .fv-txt{
  /* font-size: 20px; */
  font-size: 4.444vw;
  font-weight: bold;
  line-height: 1.5;
  text-align: center;
  padding-right: 16px;
  padding-left: 16px;
  margin-bottom: 19.444vw;
}
.fv .fv-txt p:not(:last-child){
  margin-bottom: 6.667vw;
}

.fv .fv-illust{
  width: 100%;
  margin: 0 auto;
}
.fv .fv-illust-img{}


/* その他事例 */
.others-approach-sec{}
.others-approach-sec .sec-ttl {
  margin-bottom: 20px;
  text-align: center;
}
.others-approach-sec .anatatodocomo-link-list .link-tile .link-ttl a{
  display: block;
}
.others-approach-sec .anatatodocomo-link-list .link-tile .link-ttl a[target="_blank"]{
  display: flex;
  align-items: center;
}
.others-approach-sec .anatatodocomo-link-list .link-tile .link-ttl a[target="_blank"] .link-ttl-inner{
  width: calc(100% - 15px);
}
.others-approach-sec .anatatodocomo-link-list .link-tile .link-ttl a .icon-blank{
  display: block;
  text-indent: -9999px;
  margin-top: 5px;
  margin-left: 5px;
  width: 10px;
  height: 10px;
  background-position: center center;
  background-size: 100%;
  background-image: url(/corporate/images/common/ico_external.svg);
  transition: all 0.3s ease;
}
.others-approach-sec .anatatodocomo-link-list .link-tile .link-ttl a[target="_blank"]:hover .icon-blank{
  background-image: url(/corporate/images/common/ico_external_red.svg);
}




.mv-area {
  position: relative;
/*  margin-bottom: -24px;*/
}
.mv-area .mv-slider {
  width: 100%;
  padding: 0;
  position: relative;
}
.mv-area .mv-slider .slick-slide {
  padding: 0;
}
.mv_logo {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}
.cmn-sec.pink-sec {
  background-color: #FAEFF1;
  padding: 50px 0 60px;
  margin-top: 50px;
}
.cmn-sec{
  margin-top: 0;
  padding-top: 50px;
}
.cmn-sec.gray-sec {
  background-color: #fafafa;
  padding: 50px 0 60px;
  margin-top: 50px;
}
.pink-sec + .gray-sec {
  margin-top: 0;
}


.video-sec iframe{
  max-width: 100%;  
}




/*mod-shop-map*/

:root {
  --hokkaido: #C03;
  --tohoku: #A85157;
  --kanto: #F87785;
  --tokai: #E58A8A;
  --hokuriku: #FDB1C5;
  --kansai: #FFAA49;
  --chugoku: #D7964D;
  --shikoku: #F19248;
  --kyushu: #FFD280;
}

.sec-map{
  padding: 0;
}

.mod-shop-map_bk {
  position: relative;
  max-width: 480px;
  background: url(/corporate/csr/activity/images/img_map_bg_smt.png) no-repeat;
  background-size: cover;
  background-position: center;
  margin: 24px auto;
  padding: 84px 0;
}

.mod-shop-map {
  position: relative;
  margin: 52px auto 50px;
  height: 215px;
  width: 320px;
  background: url(/corporate/csr/activity/images/img_map_japan01.png) no-repeat;
  background-size: contain;
  background-position: center;
}

.mod-shop-map .map-read{
  position: absolute;
  top: -41%;
  left: 50%;
  transform: translateX(-48%);
  width: 210px;
  font-size: 14px;
  font-weight: 700;
  color: #333;
  text-align: center;
}

.mod-shop-map .item {
  position: absolute;
}
.mod-shop-map .item.s-hokkaido {
  top: -22%;
  left: 51%;
}
.mod-shop-map .item.s-hokkaido:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 100%;
  width: 50px;
  height: 23px;
  border-top: 2px solid var(--hokkaido);
  border-right: 2px solid var(--hokkaido);
}
.mod-shop-map .item.s-tohoku {
  top: 6%;
  left: 51%;
}
.mod-shop-map .item.s-tohoku:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 100%;
  width: 15px;
  height: 45px;
  border-top: 2px solid var(--tohoku);
  border-right: 2px solid var(--tohoku);
}
.mod-shop-map .item.s-tohoku:after {
  content: "";
  display: block;
  position: absolute;
  top: calc(50% + 45px);
  left: calc(100% + 16px);
  width: 10px;
  height: 1px;
  border-top: 2px solid var(--tohoku);
}
.mod-shop-map .item.s-kanto {
  top: 105%;
  left: 75%;
}
.mod-shop-map .item.s-kanto:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 100%;
  right: 50%;
  width: 15px;
  height: 11px;
  border-top: 2px solid var(--kanto);
  border-right: 2px solid var(--kanto);
}
.mod-shop-map .item.s-kanto:after {
  content: "";
  display: block;
  position: absolute;
  bottom: calc(100% + 11px);
  right: calc(50% + 16px);
  width: 1px;
  height: 17px;
  border-right: 2px solid var(--kanto);
}
.mod-shop-map .item.s-tokai {
  top: 105%;
  left: 51%;
}
.mod-shop-map .item.s-tokai:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 100%;
  right: 50%;
  width: 1px;
  height: 27px;
  border-right: 2px solid var(--tokai);
}
.mod-shop-map .item.s-hokuriku {
  top: 6%;
  left: 27%;
}
.mod-shop-map .item.s-hokuriku:before {
  content: "";
  display: block;
  position: absolute;
  top: 100%;
  left: 50%;
  width: 83px;
  height: 11px;
  border-left: 2px solid var(--hokuriku);
  border-bottom: 2px solid var(--hokuriku);
}
.mod-shop-map .item.s-hokuriku:after {
  content: "";
  display: block;
  position: absolute;
  top: calc(100% + 11px);
  left: calc(50% + 84px);
  width: 1px;
  height: 39px;
  border-left: 2px solid var(--hokuriku);
}
.mod-shop-map .item.s-kansai {
  top: 6%;
  left: 3%;
}
.mod-shop-map .item.s-kansai:before {
  content: "";
  display: block;
  position: absolute;
  top: 100%;
  left: 50%;
  width: 98px;
  height: 21px;
  border-left: 2px solid var(--kansai);
  border-bottom: 2px solid var(--kansai);
}
.mod-shop-map .item.s-kansai:after {
  content: "";
  display: block;
  position: absolute;
  top: calc(100% + 22px);
  left: calc(50% + 98px);
  width: 1px;
  height: 57px;
  border-left: 2px solid var(--kansai);
}
.mod-shop-map .item.s-chugoku {
  top: 34%;
  left: 3%;
}
.mod-shop-map .item.s-chugoku:before {
  content: "";
  display: block;
  position: absolute;
  top: 100%;
  left: 50%;
  width: 31px;
  height: 28px;
  border-left: 2px solid var(--chugoku);
  border-bottom: 2px solid var(--chugoku);
}
.mod-shop-map .item.s-shikoku {
  top: 105%;
  left: 27%;
}
.mod-shop-map .item.s-shikoku:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 100%;
  right: 50%;
  width: 15px;
  height: 11px;
  border-top: 2px solid var(--shikoku);
  border-right: 2px solid var(--shikoku);
}
.mod-shop-map .item.s-shikoku:after {
  content: "";
  display: block;
  position: absolute;
  bottom: calc(100% + 11px);
  right: calc(50% + 17px);
  width: 1px;
  height: 11px;
  border-right: 2px solid var(--shikoku);
}
.mod-shop-map .item.s-kyushu {
  top: 105%;
  left: 3%;
}
.mod-shop-map .item.s-kyushu:before {
  content: "";
  display: block;
  position: absolute;
  bottom: 100%;
  right: 50%;
  width: 1px;
  height: 11px;
  border-right: 2px solid var(--kyushu);
}
.mod-shop-map .item .tit {
  margin-bottom: 5px;
}
.mod-shop-map .item .tit:last-child {
  margin: 5px 0 5px;
}
.mod-shop-map .item .tit a {
  color: #000;
  font-weight: bold;
  text-decoration: none;
}
.mod-shop-map .item .list > div > .btn-cmn {
  width: 70px;
  height: 30px;
  padding: 6px 4px 6px 2px;
  background-image: none;
  color: #333;
  text-align: center;
}
.mod-shop-map .item.s-hokkaido .list > div > .btn-cmn {
  background-color: var(--hokkaido);
  color: #fff;
}
.mod-shop-map .item.s-tohoku .list > div > .btn-cmn {
  background-color: var(--tohoku);
  color: #fff;
}
.mod-shop-map .item.s-kanto .list > div > .btn-cmn {
  background-color: var(--kanto);
}
.mod-shop-map .item.s-tokai .list > div > .btn-cmn {
  background-color: var(--tokai);
}
.mod-shop-map .item.s-hokuriku .list > div > .btn-cmn {
  background-color: var(--hokuriku);
}
.mod-shop-map .item.s-kansai .list > div > .btn-cmn {
  background-color: var(--kansai);
}
.mod-shop-map .item.s-chugoku .list > div > .btn-cmn {
  background-color: var(--chugoku);
}
.mod-shop-map .item.s-shikoku .list > div > .btn-cmn {
  background-color: var(--shikoku);
}
.mod-shop-map .item.s-kyushu .list > div > .btn-cmn {
  background-color: var(--kyushu);
}
.mod-shop-map .item .list > div > .btn-cmn:visited {
  color: #333;
}
.mod-shop-map .item.s-hokkaido .list > div > .btn-cmn:visited,
.mod-shop-map .item.s-tohoku .list > div > .btn-cmn:visited {
  color: #fff;
}
.mod-shop-map .item .list > div > .btn-cmn:after,
.mod-shop-map .item .list > div > .btn-cmn:hover:after {
  border:none;
}
.mod-shop-map .item .list > div.last > .btn-cmn {
  margin-top: -1px;
}
.mod-shop-map .item .list > div > .btn-cmn:not(.s-bdb):after {
  border-bottom: none;
}
.mod-shop-map .item .list > div > .btn-cmn > .inner {
  font-size: 10px;
}
.mod-shop-map .item .list > div > .btn-cmn:hover {
  z-index: 100;
}






/* carousel-3col */

:root {
  --red: #C03;
  --black: #333;
}


.carousel-3col {
  width: 100vw;
  margin-left: calc(50% - 50vw);
}

.carousel-3col-inner {
  display: flex;
  justify-content: center;
  width: min(100%, 800px);
  margin: 0 auto;
  overflow: hidden;
}

.carousel-3col-inner-main {
  display: flex;
  width: 104%;
}

.carousel-3col-inner-main.slick-initialized {
  display: block;
}

.carousel-3col-inner-main-item {
  margin: 0 5.4vw;
  padding: 0;
}

.carousel-3col-inner-main-item-link {
  color: #000;
  text-decoration: none;
  transition: -webkit-text-decoration 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  transition: text-decoration 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
  transition: text-decoration 0.3s cubic-bezier(0.39, 0.575, 0.565, 1), -webkit-text-decoration 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.carousel-3col-inner-main-item-link:hover,
.carousel-3col-inner-main-item-link:visited,
.carousel-3col-inner-main-item-link:focus-visible,
.carousel-3col-inner-main-item-link:focus-visible {
  color: #000;
}

.carousel-3col-inner-main-item-link:hover .carousel-3col-inner-main-item-link-desc-info,
.carousel-3col-inner-main-item-link:visited .carousel-3col-inner-main-item-link-desc-info,
.carousel-3col-inner-main-item-link:focus-visible .carousel-3col-inner-main-item-link-desc-info,
.carousel-3col-inner-main-item-link:focus-visible .carousel-3col-inner-main-item-link-desc-info {
  text-decoration: underline;
}

.carousel-3col-inner-main-item-link-img {
  position: relative;
  width: 100%;
}

.carousel-3col-inner-main-item-link-img .thumbnail {
  width: 100%;
}

.carousel-3col-inner-main-item-link-img .play-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 40px;
  height: 40px;
  z-index: 1;
}

.carousel-3col-inner-main-item-link-desc {
  margin-top: 10px;
}

.carousel-3col-inner-main-item-link-desc-title {
  font-size: 16px;
  color: var(--black);
  font-weight: bold;
}

.carousel-3col-inner-main-item-link-desc-info {
  margin-top: 3px;
}

.carousel-3col-inner-main-item-link-desc-info p {
  font-size: 16px;
  color: var(--black);
  margin: 0;
}

.carousel-3col-arrows {
  --x: 10.15vw;
  --y: 53vw;
  --s: 9vw;
  position: relative;
  width: 100%;
}

.carousel-3col-arrows .slick-prev {
  position: absolute;
  top: var(--y);
  left: var(--x);
  width: var(--s);
  height: var(--s);
  background: transparent;
  border: none;
  font-size: 0;
  z-index: 1;
  cursor: pointer;
}

.carousel-3col-arrows .slick-prev::before {
  content: "";
  display: block;
  width: var(--s);
  height: var(--s);
  background-image: url("/corporate/csr/activity/images/ico_slick-arrow.svg");
  background-repeat: no-repeat;
  background-size: cover;
  transform: rotate(180deg);
}

.carousel-3col-arrows .slick-next {
  position: absolute;
  top: var(--y);
  right: var(--x);
  width: var(--s);
  height: var(--s);
  background: transparent;
  border: none;
  font-size: 0;
  z-index: 1;
  cursor: pointer;
}

.carousel-3col-arrows .slick-next::before {
  content: "";
  display: block;
  width: var(--s);
  height: var(--s);
  background-image: url("/corporate/csr/activity/images/ico_slick-arrow.svg");
  background-repeat: no-repeat;
  background-size: cover;
}

.carousel-3col .slick-dots {
  bottom: unset;
  width: 100%;
  padding: 0;
  display: flex;
  gap: 4px;
  justify-content: center;
  list-style: none;
  margin-top: 5vw;
}

.carousel-3col .slick-dots li {
  --s: 10px;
}

.carousel-3col .slick-dots li button {
  width: var(--s);
  height: var(--s);
  padding: 0;
  border-radius: 100vw;
  border: 1px solid var(--red);
  background: #fff !important;
  font-size: 0;
}

.carousel-3col .slick-dots li button:focus {
  outline: 2px solid #000;
}

.carousel-3col .slick-dots li button::before {
  background: transparent !important;
}

.carousel-3col .slick-dots li.slick-active button {
  background: var(--red) !important;
}

.carousel-3col .slick-slider {
  margin-bottom: 40px;
}



/* 統合する時に修正して削除 */


.sec-map .txt-selectpoint02 {
  line-height: 1.1;
  margin-bottom: 24px;
}
.sec-map .txt-selectpoint02 .attention .attention-read {
  position: relative;
  display: inline-block;
}
.txt-selectpoint02 .attention .attention-read::before, .txt-selectpoint02 .attention .attention-read::after {
  display: block;
  position: absolute;
  content: "";
  background: #c03;
  width: 2px;
  height: 60px;
}
.txt-selectpoint02 .attention .attention-read::before {
  transform: rotate(-35deg);
  bottom: -3px;
  left: -36px;
}
.txt-selectpoint02 .attention .attention-read::after {
  transform: rotate(35deg);
  bottom: -3px;
  right: -26px;
}
.sec-map .txt-selectpoint02 .attention .attention-txt{
  display: inline-block;
  line-height: 1.7;
  font-size: 14px;
  padding-top: 11px;
}




/*pickup_bnr_item_area_pc3col_smt1col*/
.pickup_bnr_item_area_pc3col_smt1col {
  margin-top: 20px;
}

.pickup_bnr_lists_pc3col_smt1col {
  display: flex;
  flex-direction: column;
  row-gap: 8px;
}

.pickup_bnr_list_pc3col_smt1col {
  display: flex;
  flex-direction: column;
}

.pickup_bnr_link_pc3col_smt1col {
  display: flex;
  text-decoration: none;
  color: #000;
  font-weight: 300;
  line-height: 1.5;
  font-size: clamp(1.2rem, 1.128rem + 0.32vw, 1.4rem);
  transition: all .3s cubic-bezier(.39, .575, .565, 1);
  padding-bottom: 8px;
  border-bottom: 1px dashed #CCC;
  column-gap: 15px;
}

.pickup_bnr_item_area_pc3col_smt1col .pickup_bnr_link_pc3col_smt1col:focus,
.pickup_bnr_item_area_pc3col_smt1col .pickup_bnr_link_pc3col_smt1col:hover,
.pickup_bnr_item_area_pc3col_smt1col .pickup_bnr_link_pc3col_smt1col:visited,
.pickup_bnr_item_area_pc3col_smt1col .pickup_bnr_link_pc3col_smt1col:focus-visible {
  color: #CC0033;
}

.pickup_bnr_img_pc3col_smt1col {
  width: 34.334vw;
  height: 15.556vw;
  object-fit: cover;
  display: block;
}

.pickup_bnr_ttl_area_pc3col_smt1col {
  display: flex;
  align-items: center;
  width: 100%;
  column-gap: 4px;
}

.pickup_bnr_ttl_pc3col_smt1col {
  width: calc(100% - 27px);
}

.arrow-right-link-3col {
  position: relative;
}

.arrow-right-link-3col:after {
  height: auto;
}

.txt-selectpoint01 .attention {
  position: relative;
  display: inline-block;
}
.txt-selectpoint01 .attention::before, .txt-selectpoint01 .attention::after {
  position: relative;
  display: inline-block;
  content: "";
  background: #c03;
  width: 2px;
  height: 75px;
  margin: 0 1em;
  margin-top: 0.1em;
  vertical-align: middle;
  border-radius: 5px;
}
.txt-selectpoint01 .attention::before {
  transform: rotate(-35deg);
}
.txt-selectpoint01 .attention::after {
  transform: rotate(35deg);
}

.img-wrap-border {
  border: 1px solid #ccc;
}

.col3-img-box-link a {
  text-decoration: none;
}

.arrow-right-link-3col::after {
  background: url(/corporate/images/common/ico_arrow_circle.svg) no-repeat center center / 22px auto;
  content: "";
  display: inline-block;
  width: 24px;
  height: 24px;
  position: absolute;
  right: 3px;
  top: 50%;
  transform: translateY(-50%) rotate(0deg);
  transition: all 0.3s ease;
}

.ico-right-window-right {
  position: relative;
  display: inline-block;
}

.ico-right-window-right::after {
  margin-right: 5px;
  background: url(/corporate/images/common/ico_external_red.svg) no-repeat right 1px center;
  content: "";
  width: 24px;
  height: 24px;
  background-size: 10px;
  position: absolute;
  right: -5px;
  top: 95%;
}

.arrow-right-link-right {
  position: relative;
  display: inline-block;
}

.arrow-right-link-right::after {
  margin-right: 5px;
  background: url(/corporate/images/common/ico_arrow_down.svg) no-repeat center center / contain;
  content: "";
  width: 24px;
  height: 24px;
  background-size: 10px;
  position: absolute;
  right: -5px;
  top: 90%;
  transform: translateY(50%) rotate(-90deg);
}


/* 動画モーダル画角調整 */

#modal-content{
  height: 100vh;
}
#modal-content .inner{
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: 0;
  margin-inline: auto;
  height: 100vh;
  width: 100%;
  position: relative;
}
#modal-content .modal-unit{
  aspect-ratio: 9 /16;
  position: relative;
  height: 70%;
  width: auto;
}
#modal-content .inner #player{
  position: static;
  top: auto;
  left: auto;
  z-index: auto;
}
#modal-content .modal-close{
  left: 0;
}

@media screen and (orientation: landscape){
  #modal-content .modal-unit{
    top: 20px;
  }
}

