@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%;
}

/* ------------------------------------------------
/* alphainfo
/* header stylesheet
/* createAt: 2020.09.23
/* author: shotanaka
/* ------------------------------------------------ */
.tpl__alphainfo__header {
    background: #000;
}

.tpl__alphainfo__header--inner {
    width: 93.75%;
    max-width: 1200px;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    box-sizing: border-box;
    margin: 0 auto;
}

.tpl__alphainfo__header--logo {
    display: block;
    padding: 15px 0;
    width: 80px;
}

@media screen and (min-width: 640px) {
    .tpl__alphainfo__header--logo {
        width: 100px;
    }
}

.tpl__alphainfo__header--txt {
    margin-left: auto;
    padding: 14px 0 18px;
    width: 52%;
    line-height: 0;
}

@media screen and (min-width: 640px) {
    .tpl__alphainfo__header--txt {
        width: 300px;
    }
}

@media screen and (min-widht: 960px) {
    .tpl__alphainfo__header--txt {
        width: 351px;
    }
}

.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 .academy-logo {
    display: block;
    margin-top: 6px;
    max-width: 206px;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-title-text .academy-logo {
        display: inline-block;
        margin-top: 0;
        margin-left: .5em;
    }
}

.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;
}

.tpl__arrow--block-2col {
    margin-top: 30px;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-2col {
        display: flex;
        margin-top: 30px;
    }
}

.tpl__arrow--block-2col-imgbox img {
    width: 100%;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-2col-imgbox {
        flex: 0 0 50%;
        max-width: 50%;
    }
}

.tpl__arrow--block-2col-textbox {
    line-height: 1.5;
    margin-top: 20px;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-2col-textbox {
        flex: 0 1 auto;
        margin-top: 0;
        margin-left: 40px;
		max-width: 45%;
    }
}

.tpl__arrow--block-2col-upper-subtitle {
    font-size: 13px;
    font-size: 0.8125rem;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-2col-upper-subtitle {
        font-size: 16px;
        font-size: 1rem;
    }
}

.tpl__arrow--block-2col-title {
    font-size: 20px;
    font-size: 1.25rem;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-2col-title {
        font-size: 25px;
        font-size: 1.5625rem;
    }
}

.tpl__arrow--block-2col-title + .tpl__arrow--block-2col-text {
    margin-top: 10px;
}

.tpl__arrow--block-2col-text, .tpl__arrow--block-2col-dl {
    line-height: 1.7;
    font-size: 15px;
    font-size: 0.9375rem;
    letter-spacing: -.01em;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-2col-text, .tpl__arrow--block-2col-dl {
        font-size: 19px;
        font-size: 1.1875rem;
    }
}

.tpl__arrow--block-2col-text + .tpl__arrow--block-2col-dl {
    margin-top: 16px;
}

.tpl__arrow--block-2col-dl .row {
    display: flex;
}

.tpl__arrow--block-2col-dl dt {
    flex: 0 0 auto;
}

.tpl__arrow--block-2col-dl dd {
    margin-left: 4px;
}

.tpl__arrow--block-2col-caption {
    font-size: 14px;
    font-size: 0.875rem;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-2col-caption {
        font-size: 17px;
        font-size: 1.0625rem;
    }
}

.tpl__arrow--block-2col-btn {
    line-height: 1.2;
    text-align: center;
    width: 100%;
    padding: 16px;
    display: block;
    background: #5787e4;
    color: #fff;
    transition: .3s !important;
    font-size: 15px;
    font-size: 0.9375rem;
    position: relative;
    margin-top: 10px;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-2col-btn {
        font-size: 19px;
        font-size: 1.1875rem;
		margin-top: 22%;
    }
}

.tpl__arrow--block-2col-btn:hover, .tpl__arrow--block-2col-btn:focus {
    background: #99b6ef;
    color: #fff;
    text-decoration: none;
}

.tpl__arrow--block-2col-btn::before {
    content: '';
    display: block;
    position: absolute;
    left: 22px;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4.5px 0 4.5px 7px;
    border-color: transparent transparent transparent #fff;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-2col-btn::before {
        left: 116px;
		left: 33px;
    }
}

.tpl__arrow--block-academy-banner {
    display: block;
    margin-top: 30px;
    transition: .3s !important;
}

.tpl__arrow--block-academy-banner:hover, .tpl__arrow--block-academy-banner:focus {
    opacity: .7;
}

.tpl__arrow--block-academy-caption {
    line-height: 1.5;
    margin-top: 20px;
    font-size: 15px;
    font-size: 0.9375rem;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-academy-caption {
        text-align: center;
        font-size: 19px;
        font-size: 1.1875rem;
    }
}

.tpl__arrow--block-academy-btn {
    margin-top: 30px;
    line-height: 1.2;
    text-align: center;
    width: 100%;
    padding: 16px;
    display: block;
    background: #5787e4;
    color: #fff;
    transition: .3s !important;
    font-size: 15px;
    font-size: 0.9375rem;
    position: relative;
    margin-top: 10px;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-academy-btn {
        font-size: 19px;
        font-size: 1.1875rem;
        margin-top: 60px;
    }
}

.tpl__arrow--block-academy-btn:hover, .tpl__arrow--block-academy-btn:focus {
    background: #99b6ef;
    color: #fff;
    text-decoration: none;
}

.tpl__arrow--block-academy-btn::before {
    content: '';
    display: block;
    position: absolute;
    left: 22px;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4.5px 0 4.5px 7px;
    border-color: transparent transparent transparent #fff;
}

@media screen and (min-width: 640px) {
    .tpl__arrow--block-academy-btn::before {
        left: 200px;
    }
}

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

  #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;
    }
}
@media screen and (max-width: 640px) {
	.sp_br{
    	display: none;
   }
}