.p-pref-mv {
  width: 100%;
  height: 430px;
  position: relative;
  overflow: hidden;
  z-index: 1; }
  .p-pref-mv__bg {
    position: absolute;
    width: 100%;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%); }
  .p-pref-mv__lead {
    position: relative;
    color: #fff;
    padding-top: 80px;
    padding-left: 40px; }
  .p-pref-mv__form {
    position: relative;
    padding-top: 25px;
    padding-left: 40px; }
  .p-pref-mv__catch {
    font-size: 20px;
    font-weight: 600;
    text-shadow: 2px 2px 3px #444; }
    .p-pref-mv__catch .-strong {
      font-size: 60px;
      line-height: 1;
      font-weight: 500; }
    .p-pref-mv__catch .-sub {
      font-size: 30px;
      padding-left: 10px; }
  .p-pref-mv__search-bar {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    background: rgba(255, 255, 255, 0.85);
    width: 500px;
    padding: 5px 20px; }
    .p-pref-mv__search-bar .-input {
      width: 290px;
      padding: 5px;
      margin-left: 40px;
      border-color: #15C1DF; }
    .p-pref-mv__search-bar .-img {
      border: none;
      padding: 0; }
  .p-pref-mv__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 15px; }
    .p-pref-mv__list > * {
      margin-right: 10px; }

.p-pref-search-btn a {
  display: block;
  background-color: #15C1DF;
  color: #fff;
  padding: 0.65em 1em;
  font-weight: 500;
  text-align: center;
  width: 160px;
  text-decoration: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  font-weight: 600; }
  .p-pref-search-btn a:hover {
    background-color: #3bd2ec; }

.p-pref-cover {
  padding: 30px 10px; }
  .p-pref-cover--bottom {
    padding: 30px 10px 80px; }

#newcom .p-pref-newcom__ttl {
  background: url(../image/pref/ttl_new_service.png) no-repeat;
  width: 100%;
  height: 60px;
  margin: 0 0 27px;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  -webkit-box-shadow: none;
          box-shadow: none; }
#newcom .p-pref-newcom__list {
  padding: 0 21px 2px; }
  #newcom .p-pref-newcom__list li {
    padding: 0 0 0 80px;
    margin: 0 0 23px; }
    #newcom .p-pref-newcom__list li.shopping {
      background: url(../image/icon/news_shopping.png) 0 1px no-repeat; }
    #newcom .p-pref-newcom__list li.business {
      background: url(../image/icon/news_business.png) 0 1px no-repeat; }

#todays .p-pref-todays__ttl {
  background: url(../image/pref/ttl_recommendation.png) no-repeat;
  width: 100%;
  height: 60px;
  margin: 0 0 27px;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  -webkit-box-shadow: none;
          box-shadow: none; }
#todays .p-pref-todays__list {
  margin-bottom: 30px; }
  #todays .p-pref-todays__list .-title {
    background: url(../image/icon/yellow_circle.png) 0 2px no-repeat;
    padding-left: 2.5em; }
  #todays .p-pref-todays__list .-text {
    padding: 1em 0 0; }
  #todays .p-pref-todays__list .-photo {
    padding: 1em 0 0;
    text-align: center; }
    #todays .p-pref-todays__list .-photo img {
      width: 275px;
      height: 140px;
      -o-object-fit: contain;
         object-fit: contain; }
      @media screen and (max-width: 955px) {
        #todays .p-pref-todays__list .-photo img {
          width: 80%;
          height: 100px; } }
#todays .p-pref-three-card {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-left: 30px;
  margin-right: 30px;
  width: calc(100% - 60px);
  -ms-flex-wrap: wrap;
      flex-wrap: wrap; }
  #todays .p-pref-three-card__item {
    width: 32%;
    margin-right: 2%; }
    #todays .p-pref-three-card__item:nth-child(3n) {
      margin-right: 0; }

.p-pref-heading {
  margin-top: 0.25em;
  text-align: center;
  font-size: 30px;
  color: #666;
  font-weight: 600; }

.p-fun-grid {
  display: grid;
  grid-template-areas: "areaT areaT" "areaL areaR" "areaB areaB";
  grid-row-gap: 30px;
  grid-column-gap: 30px;
  grid-template-columns: calc(50% -15px) calc(50% -15px);
  grid-template-columns: 1fr 1fr; }
  .p-fun-grid__item {
    background-color: #fff; }
  .p-fun-grid .-grid-wide-top {
    grid-area: areaT;
    margin-top: 30px; }
  .p-fun-grid .-grid-wide-bottom {
    grid-area: areaB; }
  .p-fun-grid .-grid-left {
    grid-area: areaL; }
  .p-fun-grid .-grid-right {
    grid-area: areaR; }

.p-fun-pickbox {
  width: 100%;
  min-height: 300px;
  position: relative;
  overflow: hidden;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  background-color: #000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  color: #fff;
  -webkit-box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.2);
          box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.2); }
  .p-fun-pickbox__bg {
    position: absolute;
    width: 100%;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    opacity: 0.8; }
    .p-fun-pickbox__bg:hover {
      -webkit-animation: none;
              animation: none; }
  .p-fun-pickbox__text {
    width: 100%;
    z-index: 1;
    padding: 30px 50px;
    color: #fff;
    text-decoration: none;
    -webkit-transition: background 0.3s ease;
    transition: background 0.3s ease; }
    .p-fun-pickbox__text .-link {
      font-weight: 600;
      font-size: 22px;
      text-decoration: underline;
      color: #fff; }
      .p-fun-pickbox__text .-link:hover {
        opacity: 1;
        -webkit-animation: blinks 1s;
                animation: blinks 1s; }
    .p-fun-pickbox__text .-txt {
      margin-top: 1em;
      text-shadow: 2px 2px 3px #444;
      font-size: 17px; }

.p-fun-links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 30px; }
  .p-fun-links__item {
    margin-left: 1em;
    margin-right: 1em; }

.p-fun-links-btn {
  border: 1px solid #ddd;
  background: rgba(255, 255, 255, 0.85);
  border-radius: 400px;
  color: #333;
  font-weight: 500;
  font-size: 18px;
  display: block;
  padding: 0.75em 1.5em;
  -webkit-transition: background 0.3s ease;
  transition: background 0.3s ease;
  line-height: 1;
  font-weight: 600; }
  .p-fun-links-btn:hover {
    text-decoration: none; }
    .p-fun-links-btn:hover:hover {
      opacity: 1;
      -webkit-animation: blinks 1s;
              animation: blinks 1s; }

.p-fun-box {
  width: 100%;
  height: 300px;
  position: relative;
  overflow: hidden;
  display: block;
  width: 100%;
  text-decoration: none;
  -webkit-box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.2);
          box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.2); }
  .p-fun-box:hover {
    text-decoration: none; }
    .p-fun-box:hover .p-fun-box__text {
      background: rgba(0, 0, 0, 0.6); }
  .p-fun-box__bg {
    position: absolute;
    width: 100%;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%); }
    @media screen and (max-width: 955px) {
      .p-fun-box__bg {
        width: 120%;
        height: auto;
        top: 50%;
        left: 50%;
        -webkit-transform: translateX(-50%) translateY(-50%);
                transform: translateX(-50%) translateY(-50%); } }
    .p-fun-box__bg:hover {
      -webkit-animation: none;
              animation: none; }
  .p-fun-box__text {
    position: absolute;
    left: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.4);
    padding: 30px 20px;
    color: #fff;
    text-decoration: none;
    -webkit-transition: background 0.3s ease;
    transition: background 0.3s ease; }
    .p-fun-box__text .-title {
      font-weight: 600;
      font-size: 20px;
      text-decoration: underline; }
    .p-fun-box__text .-txt {
      margin-top: 1em;
      font-size: 15px; }

.p-pick-grid {
  display: grid;
  grid-auto-rows: 300px;
  grid-template-columns: repeat(3, minmax(200px, 1fr));
  grid-row-gap: 10px;
  grid-column-gap: 10px;
  margin-top: 30px; }
  @media screen and (max-width: 955px) {
    .p-pick-grid {
      grid-auto-rows: 250px; } }
  .p-pick-grid__item {
    background-color: #fff;
    height: 300px;
    -webkit-box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.2);
            box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.2); }
    @media screen and (max-width: 955px) {
      .p-pick-grid__item {
        height: 250px; } }

.p-pick-box {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  text-decoration: none;
  background: #000; }
  .p-pick-box:hover {
    text-decoration: none; }
  .p-pick-box__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0.8;
    -o-object-fit: cover;
       object-fit: cover;
    -webkit-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease; }
    .p-pick-box__bg:hover {
      -webkit-animation: none;
              animation: none;
      opacity: 0.6; }
  .p-pick-box__text {
    position: relative;
    pointer-events: none;
    width: 100%;
    padding: 0 30px 30px;
    color: #fff;
    text-decoration: none;
    text-align: center; }
    .p-pick-box__text .-title {
      font-weight: 600;
      font-size: 22px;
      text-decoration: none;
      text-shadow: 2px 2px 3px #444; }
