@charset "UTF-8";
/*----------------------------------------
reset
----------------------------------------*/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}

img {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    font-size: 100%;
    vertical-align: middle;
    background: transparent;
    max-width: 100%;
}

body {
    line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
    display: block;
}

ul {
    list-style: none;
}

a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
}

input, select {
    vertical-align: middle;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

/*----------------------------------------
body
----------------------------------------*/
body {
    position: relative;
    margin: 0;
    padding: 0;
    min-height: 100%;
    font-family: sans-serif;
    font-feature-settings: 'palt' 1;
    -webkit-text-size-adjust: none;
    -webkit-font-smoothing: antialiased;
    font-family: YuGothic, '游ゴシック', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, sans-serif;
}

.serif {
    font-family: 'Noto Serif JP', "Yu Mincho", YuMincho, "游明朝", "HGS明朝", "HGP明朝", "HG明朝", serif;
}

/*----------------------------------------
br
----------------------------------------*/
br.nb36, br.nb48, br.nb64, br.nb76, br.nb10 {
    display: none;
}

@media screen and (min-width: 360px) {
    br.nb36 {
        display: inline-block;
    }
    br.b36 {
        display: none;
    }
}

@media screen and (min-width: 480px) {
    br.nb48 {
        display: inline-block;
    }
    br.b48 {
        display: none;
    }
}

@media screen and (min-width: 640px) {
    br.nb64 {
        display: inline-block;
    }
    br.b64 {
        display: none;
    }
}

@media screen and (min-width: 768px) {
    br.nb76 {
        display: inline-block;
    }
    br.b76 {
        display: none;
    }
}

@media screen and (min-width: 1024px) {
    br.nb10 {
        display: inline-block;
    }
    br.b10 {
        display: none;
    }
}

/*----------------------------------------
.mod__wrapper
----------------------------------------*/
.mod__wrapper {
    margin: 0 auto;
    max-width: 1200px;
    width: 90.625%;
}

@media screen and (min-width: 640px) {
    .mod__wrapper {
        width: 93.75%;
    }
}

.mod__wrapper--full {
    padding: 0 26px;
    width: 100%;
}

.sony-marketing-footer {
    background: #1a1a1a;
    padding: 38px 0;
}

/*!
	Modaal - accessible modals - v0.4.4
	by Humaan, for all humans.
	http://humaan.com
 */
.imgBox__zoom {
    display: block;
    position: relative;
    margin: 0 auto;
    line-height: 0;
}

.imgBox__zoom:before {
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    content: '';
    transition: background-color 0.2s;
}

.imgBox__zoom:hover:before {
    background-color: rgba(255, 255, 255, 0.3);
}

.imgBox__zoom:after {
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
    width: 18px;
    height: 18px;
    background-image: url("../img/zoom.svg");
    background-repeat: no-repeat;
    background-size: 100% 100%;
    content: '';
}

/*========================================

  .anybox__outer

========================================*/
.anybox__outer {
    position: fixed;
    z-index: 2010;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    overflow: hidden;
    transition-timing-function: ease;
    transition-property: opacity;
    text-align: center;
}

.anybox__outer:before {
    display: inline-block;
    height: 100%;
    content: '';
    vertical-align: middle;
}

/*========================================

  .anybox__wrap

========================================*/
.anybox__wrap {
    position: relative;
    z-index: 2020;
    display: inline-block;
    box-sizing: border-box;
    max-width: 100%;
    margin: 0 auto;
    text-align: left;
    vertical-align: middle;
}

/*========================================

  .anybox__content

========================================*/
.anybox__content {
    position: relative;
}

/*========================================

  .anybox__loading

========================================*/
.anybox__loading {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 24px;
    height: 24px;
    margin: auto;
    background-image: url("../img/anybox/loading@2x.gif");
    background-repeat: no-repeat;
    background-size: 100% auto;
}

/*========================================

  .anybox-backdrop

========================================*/
.anybox__backdrop {
    position: fixed;
    z-index: 2000;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    overflow: hidden;
    transition-timing-function: ease;
    transition-property: opacity;
    opacity: inherit;
}

/*========================================

  .anybox-image

========================================*/
.anybox__imageWrap {
    position: relative;
    -webkit-animation: anybox--direction_enter .4s;
    animation: anybox--direction_enter .4s;
}

.anybox--direction_next .anybox__imageWrap {
    -webkit-animation: anybox--direction_next .4s;
    animation: anybox--direction_next .4s;
}

.anybox--direction_prev .anybox__imageWrap {
    -webkit-animation: anybox--direction_prev .4s;
    animation: anybox--direction_prev .4s;
}

.anybox__imageInner {
    line-height: 0;
    position: relative;
    box-sizing: border-box;
    max-width: 100%;
    margin: 0 auto;
}

.anybox__imageInner:after {
    position: absolute;
    z-index: -1;
    top: 20px;
    right: 0;
    bottom: 0;
    left: 0;
    display: block;
    content: '';
    box-shadow: 0 0.2em 1em rgba(0, 0, 0, 0.6);
}

.anybox__imageItem {
    display: block;
    box-sizing: border-box;
    width: auto;
    max-width: 100%;
    height: auto;
    margin: 0 auto;
    padding: 20px 0 0;
}

.anybox__imageCaption {
    font-size: 13px;
    line-height: 1.2;
    display: block;
    overflow: hidden;
    max-width: 100%;
    margin-top: 10px;
    text-align: right;
    color: #fff;
}

@media (max-width: 640px) {
    .anybox__imageCaption {
        line-height: 1.5;
        text-align: center;
    }
}

.anybox__imageBlank {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

/*========================================

  .anybox-close

========================================*/
.anybox__close {
    position: absolute;
    z-index: 2030;
    top: -20px;
    right: -10px;
    width: 40px;
    height: 40px;
    cursor: pointer;
    -webkit-transition: opacity .3s;
    transition: opacity .3s;
    background-image: url("../img/anybox/icn_close.svg");
    background-repeat: no-repeat;
    background-position: center center;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.anybox--state_loading .anybox__close {
    display: none;
}

.anybox__close::-moz-focus-inner {
    padding: 0;
    border: 0;
}

.anybox__close:hover {
    opacity: .5;
}

.anybox__close:active {
    opacity: .8;
}

/*========================================

  .anybox-arrows

========================================*/
.anybox__arrows {
    position: absolute;
    top: 50%;
    right: 0;
    left: 0;
}

.anybox--state_loading .anybox__arrows {
    display: none;
}

.anybox__arrow {
    position: absolute;
    top: 0;
    bottom: 0;
    overflow: hidden;
    width: 5.2vw;
    max-width: 50px;
    height: 5.2vw;
    max-height: 50px;
    margin: auto;
    cursor: pointer;
    -webkit-transition: opacity .3s;
    transition: opacity .3s;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: 100% auto;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
}

.anybox__arrow::-moz-focus-inner {
    padding: 0;
    border: 0;
}

.anybox__arrow:hover {
    opacity: .5;
}

.anybox__arrow:active {
    opacity: .8;
}

.anybox__arrowPrev {
    left: 0;
    background-image: url("../img/anybox/icn_prev.svg");
}

.anybox__arrowNext {
    right: 0;
    background-image: url("../img/anybox/icn_next.svg");
}

/*========================================

  animation

========================================*/
/*----------------------------------------
  anybox--direction_enter
----------------------------------------*/
@-webkit-keyframes anybox--direction_enter {
    from {
        -webkit-transform: translate3d(0, -2em, 0);
        opacity: 0;
    }
    to {
        -webkit-transform: translate3d(0, 0, 0);
        opacity: 1;
    }
}

@keyframes anybox--direction_enter {
    from {
        -webkit-transform: translate3d(0, -2em, 0);
        transform: translate3d(0, -2em, 0);
        opacity: 0;
    }
    to {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
        opacity: 1;
    }
}

/*----------------------------------------
  anybox--direction_next
----------------------------------------*/
@-webkit-keyframes anybox--direction_next {
    from {
        -webkit-transform: translate3d(3em, 0, 0);
        opacity: 0;
    }
    to {
        -webkit-transform: translate3d(0, 0, 0);
        opacity: 1;
    }
}

@keyframes anybox--direction_next {
    from {
        -webkit-transform: translate3d(3em, 0, 0);
        transform: translate3d(3em, 0, 0);
        opacity: 0;
    }
    to {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
        opacity: 1;
    }
}

/*----------------------------------------
  anybox--direction_prev
----------------------------------------*/
@-webkit-keyframes anybox--direction_prev {
    from {
        -webkit-transform: translate3d(-3em, 0, 0);
        opacity: 0;
    }
    to {
        -webkit-transform: translate3d(0, 0, 0);
        opacity: 1;
    }
}

@keyframes anybox--direction_prev {
    from {
        -webkit-transform: translate3d(-3em, 0, 0);
        transform: translate3d(-3em, 0, 0);
        opacity: 0;
    }
    to {
        -webkit-transform: translate3d(0, 0, 0);
        transform: translate3d(0, 0, 0);
        opacity: 1;
    }
}

.tpl__arrow--block-title {
    background: #2a2a2a;
    color: #fff;
    padding: 16px 0;
}

.tpl__arrow--block-title-text {
    display: flex;
    align-items: center;
    font-size: 28px;
    font-size: 1.75rem;
}

.tpl__arrow--block-title-text::before {
    content: '';
    display: block;
    flex: 0 0 auto;
    max-width: 24px;
    background-image: url(../img/arrow_ttl.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center center;
    width: 19.2px;
    height: 24.8px;
    margin-right: 8px;
}

@media screen and (min-width: 1024px) {
    .tpl__arrow--block-title-text::before {
        width: 24px;
        height: 31px;
    }
}

.tpl__arrow--block-subtitle {
    margin-top: 60px;
    text-align: center;
    font-size: 22px;
    font-size: 1.375rem;
    line-height: 1.4;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-subtitle {
        margin-top: 90px;
        font-size: 30px;
        font-size: 1.875rem;
    }
}

.tpl__arrow--block-text {
    margin-top: 25px;
    line-height: 1.6;
    font-size: 16px;
    font-size: 1rem;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-text {
        font-size: 18px;
        font-size: 1.125rem;
    }
}

.tpl__arrow--block .store-list {
    margin-top: 20px;
    display: flex;
    flex-wrap: wrap;
}

@media screen and (min-width: 480px) {
    .tpl__arrow--block .store-list {
        flex-wrap: nowrap;
        margin-top: 40px;
    }
}

.tpl__arrow--block .store-item {
    flex: 0 0 48%;
    width: 48%;
}

.tpl__arrow--block .store-item:nth-of-type(even) {
    margin-left: 4%;
}

.tpl__arrow--block .store-item:nth-of-type(n+3) {
    margin-top: 4%;
}

.tpl__arrow--block .store-item img {
    width: 100%;
}

@media screen and (min-width: 480px) {
    .tpl__arrow--block .store-item {
        flex: 0 0 17.643%;
        width: 17.643%;
    }
    .tpl__arrow--block .store-item:nth-of-type(even) {
        margin-left: 2%;
    }
    .tpl__arrow--block .store-item:nth-of-type(n+3) {
        margin-top: 0;
        margin-left: 2%;
    }
}

.tpl__arrow--block .store-link {
    transition: .3s !important;
}

.tpl__arrow--block .store-link:hover, .tpl__arrow--block .store-link:focus {
    opacity: .7;
}

/*========================================

  #Ques

========================================*/
#Ques {
    padding: 40px 0 40px;
    background-color: #eaeaea;
}

#Ques h3 {
    text-align: center;
    font-size: 24px;
    font-size: 1.5rem;
    color: #555;
    line-height: 1.5;
    letter-spacing: .05em;
}

#Ques h3 img {
    width: 100%;
    height: auto;
}

#Ques p {
    margin: 20px 0;
    font-size: 14px;
    font-size: 0.875rem;
    line-height: 1.6;
    text-align: center;
}

#Ques p br {
    display: none;
}

#Ques .btn-box {
    overflow: hidden;
    text-align: center;
}

#Ques .btn-box img {
    margin-left: -35%;
    width: 170%;
}

#Ques .btn {
    font-size: 16px;
    font-size: 1rem;
    font-weight: bold;
    display: block;
    padding: 18px 0;
    background: #e06909;
    line-height: 1.0;
    color: #fff;
    text-decoration: none;
    transition: .3s !important;
}

#Ques .btn:hover, #Ques .btn:focus {
    background: #f68326;
}

@media screen and (min-width: 640px) {
    #Ques {
        padding: 60px 0 47px;
    }
    #Ques h3 {
        font-size: 43px;
        font-size: 2.6875rem;
    }
    #Ques p {
        font-size: 19px;
        font-size: 1.1875rem;
        margin: 30px 0 35px;
    }
    #Ques p br {
        display: inline-block;
    }
    #Ques .btn {
        font-size: 28px;
        font-size: 1.75rem;
        font-weight: normal;
    }
}

.s5-returnToTop {
    margin: 0px 0 0 !important;
}
