.fancybox-close {
    background: url(//www.tamron.jp/assets/img/plugin/fancybox/btn_close.png) no-repeat 0 0 !important
}

.utility section {
    font-size: 14px
}

@media (max-width: 767px) {
    .utility header#siteHeader nav#siteNaviSP ul li a {
        font-size: 4.6vw
    }
}

.utility .forPC {
    display: block
}

@media (max-width: 767px) {
    .utility .forPC {
        display: none
    }
}

.utility .forSP {
    display: none
}

@media (max-width: 767px) {
    .utility .forSP {
        display: block
    }
}

.utility #overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: rgba(242, 242, 242, 0.9);
    z-index: 2
}

.utility img {
    max-width: 100%
}

.utility .inner {
    max-width: 1200px;
    margin: 0 auto;
    width: 100%;
    padding: 0 20px;
    box-sizing: border-box
}

.utility .flex {
    display: flex
}

.utility p.btn {
    margin-bottom: 20px
}

.utility p.btn a {
    display: block;
    background: #005bac;
    font-size: 18px;
    color: #fff;
    max-width: 550px;
    width: 100%;
    text-align: center;
    padding: 10px 0;
    font-weight: bold;
    transition: all ease .4s
}

@media (max-width: 767px) {
    .utility p.btn a {
        font-size: 4.6vw
    }
}

.utility p.btn a:hover {
    color: #fff !important
}

.utility p.btn a:after {
    content: "";
    display: inline-block;
    background: url(../img/ico01.png) no-repeat;
    width: 20px;
    height: 20px;
    background-size: contain;
    position: relative;
    top: 0;
    margin-left: 10px
}

@media (max-width: 767px) {
    .utility p.btn a:after {
        width: 4.5vw;
        height: 4.5vw
    }
}

.utility p.btn.gray a {
    background: #777777;
    display: flex;
    justify-content: center;
    align-items: center
}

.utility p.btn.gray a::after {
    background: url(../img/ico02.png) no-repeat;
    background-size: contain
}

.utility a {
    transition: all ease .4s
}

.utility a:hover {
    transition: all ease .4s;
    opacity: .75
}

.utility header#siteHeader {
    background: #fafafa
}

.utility .bread {
    display: flex;
    justify-content: space-between;
    padding: 30px 0
}

.utility .bread ul {
    display: flex;
    padding-right: 20px
}

@media (max-width: 767px) {
    .utility .bread ul {
        display: none
    }
}

.utility .bread ul li {
    margin-right: 15px;
    padding-right: 15px;
    border-right: 1px solid #888888
}

.utility .bread ul li:last-child {
    margin: 0;
    padding: 0;
    border: none
}

.utility .bread ul li a {
    font-weight: bold
}

.utility .mv {
    text-align: center
}

.utility .mv img {
    width: 100%
}

.utility .sec01 {
    background: #000;
    color: #fff;
    padding: 70px 0
}

@media (max-width: 767px) {
    .utility .sec01 {
        padding: 16vw 0
    }
}

.utility .sec01 h2 {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 40px;
    line-height: 1.4
}

@media (max-width: 767px) {
    .utility .sec01 h2 {
        font-size: 4.5vw;
        margin-bottom: 8vw
    }
}

.utility .sec01 p {
    line-height: 1.8;
    margin-bottom: 30px
}

@media (max-width: 767px) {
    .utility .sec01 p {
        font-size: 3.4vw;
        margin-bottom: 6vw
    }
}

.utility .sec01 p.btn {
    margin-bottom: 20px
}

.utility .sec01 p.btn a {
    display: block;
    background: #005bac;
    font-size: 18px;
    color: #fff;
    max-width: 550px;
    width: 100%;
    text-align: center;
    padding: 10px 0;
    font-weight: bold;
    transition: all ease .4s
}

@media (max-width: 767px) {
    .utility .sec01 p.btn a {
        font-size: 4.2vw
    }
}

.utility .sec01 p.btn a:hover {
    color: #fff !important
}

.utility .sec01 p.btn a:after {
    content: "";
    display: inline-block;
    background: url(../img/ico01.png) no-repeat;
    width: 20px;
    height: 20px;
    background-size: contain;
    position: relative;
    top: .2em;
    margin-left: 10px
}

@media (max-width: 767px) {
    .utility .sec01 p.btn a:after {
        width: 4.5vw;
        height: 4.5vw
    }
}

.utility .sec01 p.btn.gray a {
    display: block;
    background: #777777
}

.utility .sec01 p.btn.gray a:after {
    background: url(../img/ico02.png) no-repeat;
    background-size: contain
}

.utility .sec01 p.googleplay.btn a:after {
    background: url(../img/ico01.png) no-repeat;
    background-size: contain
}

.utility .sec01 .flex {
    justify-content: space-between
}

@media (max-width: 767px) {
    .utility .sec01 .flex {
        display: block
    }
}

.utility .sec01 .left {
    width: 50%
}

@media (max-width: 767px) {
    .utility .sec01 .left {
        width: 100%;
        float: none
    }
}

.utility .sec01 .right {
    max-width: 580px;
    width: 50%
}

@media (max-width: 767px) {
    .utility .sec01 .right {
        width: 100%;
        max-width: none;
        float: none;
        padding: 10vw 0 6vw
    }
}

@media (max-width: 767px) {
    .utility .sec02 {
        padding: 14vw 0 0
    }
}

.utility .sec02 .movWrap {
    text-align: center;
    margin-bottom: 0
}

.utility .sec02 .movWrap .col {
    float: none;
    margin-bottom: 0
}

.utility .sec02 .movWrap .col a figure img {
    width: auto;
    margin: 0 auto
}

.utility .sec02 .column.video .col a figure:before {
    background: transparent url(//www.tamron.jp/assets/img/common/icon_play.png) center center no-repeat
}

.utility .sec03 {
    padding-top: 80px
}

@media (max-width: 767px) {
    .utility .sec03 {
        padding-top: 17vw
    }
}

.utility .sec03 h3 {
    font-size: 24px;
    font-weight: bold;
    margin-bottom: 15px
}

@media (max-width: 767px) {
    .utility .sec03 h3 {
        font-size: 4.7vw;
        margin-bottom: 5vw
    }
}

@media (max-width: 767px) {
    .utility .sec03 h3+p {
        font-size: 3.4vw
    }
}

.utility .sec03 .func {
    flex-wrap: wrap;
    padding: 30px 0 0;
    justify-content: space-between
}

@media (max-width: 767px) {
    .utility .sec03 .func {
        display: block;
        padding: 4vw 0 0
    }
}

.utility .sec03 .func .box {
    width: 48%;
    padding: 30px 45px 30px 20px;
    background: url(../img/plus.png) no-repeat center right 15px;
    border-bottom: 1px solid #757575;
    cursor: pointer
}

@media (min-width: 768px) {
    .utility .sec03 .func .box {
        transition: all ease .4s
    }

    .utility .sec03 .func .box:hover {
        transition: all ease .4s;
        background-color: #fff
    }
}

@media (max-width: 767px) {
    .utility .sec03 .func .box {
        padding: 6.5vw 0 5.5vw 0;
        width: 100%;
        background: url(../img/down.png) no-repeat top 16vw right;
        background-size: 4vw auto
    }
}

@media (max-width: 767px) {
    .utility .sec03 .func .box.on {
        background: url(../img/up.png) no-repeat top 16vw right;
        background-size: 4vw auto
    }
}

.utility .sec03 .func .box .flex {
    align-items: center
}

.utility .sec03 .func .box .flex p {
    line-height: 1.4;
    font-size: 16px;
    min-width: 189px
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .flex p {
        width: 35%;
        font-size: 4vw;
        min-width: 1px
    }
}

.utility .sec03 .func .box .flex div {
    padding-left: 40px
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .flex div {
        padding: 0 6vw 0 4vw;
        width: 65%
    }
}

.utility .sec03 .func .box .flex div h4 {
    font-weight: bold;
    font-size: 18px;
    margin-bottom: 10px;
    line-height: 1.4
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .flex div h4 {
        font-size: 4.5vw;
        line-height: 1.2;
        word-break: break-word
    }
}

.utility .sec03 .func .box .flex div p {
    width: 100%
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .flex div p {
        font-size: 3.4vw
    }
}

.utility .sec03 .func .box .features {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 90%;
    max-width: 1100px;
    z-index: 5
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .features {
        position: static;
        width: 100%
    }
}

.utility .sec03 .func .box .features .inner {
    padding: 45px;
    display: flex;
    justify-content: space-between;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #fff;
    cursor: auto
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .features .inner {
        position: static;
        width: 100%;
        transform: none;
        display: block;
        padding: 3vw 0 0;
        background: none
    }
}

.utility .sec03 .func .box .features .inner>span {
    display: block;
    position: absolute;
    top: -45px;
    right: 0;
    background: url(../img/close.png) no-repeat center center;
    width: 35px;
    height: 35px
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .features .inner>span {
        display: none
    }
}

.utility .sec03 .func .box .features .inner p {
    max-width: calc(100% - 455px);
    width: 55%;
    line-height: 1.6
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .features .inner p {
        width: 100%;
        max-width: none;
        font-size: 3.6vw;
        line-height: 1.6
    }
}

.utility .sec03 .func .box .features .inner p:last-of-type {
    text-align: center;
    max-width: 455px;
    width: 45%
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .features .inner p:last-of-type {
        width: 100%;
        max-width: none;
        padding-top: 4vw;
        display: none
    }
}

.utility .sec03 .func .box .features .inner p a {
    display: block;
    color: #005bac;
    text-decoration: none;
    padding: 15px 0
}

.utility .sec03 .func .box .features .inner p span {
    font-size: 16px;
    font-weight: bold;
    display: block;
    margin-bottom: 5px
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .features .inner p span {
        display: none
    }
}

.utility .sec03 .func .box .features .inner p span.s_ttl {
    font-size: 16px;
    margin-bottom: 5px
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .features .inner p span.s_ttl {
        font-size: 4vw;
        display: block;
        margin-bottom: 2vw
    }
}

.utility .sec03 .func .box .features .inner p span.s_ttl2 {
    font-size: 14px;
    margin-bottom: 0
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .features .inner p span.s_ttl2 {
        font-size: 3.6vw;
        display: block
    }
}

.utility .sec03 .func .box .features .inner p span.ttl {
    font-size: 20px;
    margin-bottom: 15px
}

.utility .sec03 .func .box .features .inner p small {
    font-size: 12px
}

@media (max-width: 767px) {
    .utility .sec03 .func .box .features .inner p small {
        font-size: 3vw
    }
}

.utility .btns {
    display: flex;
    justify-content: center;
    padding: 30px 0 0 0
}

@media (max-width: 767px) {
    .utility .btns {
        display: block;
        padding: 0 20px 22vw
    }
}

.utility .btns .btn {
    width: 550px;
    margin: 0 15px
}

@media (max-width: 767px) {
    .utility .btns .btn {
        width: 100%;
        margin: 0
    }
}

.utility .btns .btn a {
    padding: 15px 0;
    display: flex;
    justify-content: center;
    align-items: center
}

.utility .sec02,
.utility .sec03,
.utility .btns {
    background: #efefef
}

.utility .caution {
    background: #fff;
    padding: 4.8vw;
    line-height: 1.5;
    margin-bottom: 5vw;
    font-size: 3.6vw;
    color: #333
}

.utility .firstTxtWrap {
    text-align: center;
    padding: 60px 0 50px;
    display: none
}

@media (max-width: 767px) {
    .utility .firstTxtWrap {
        padding: 2vw 0 12vw
    }
}

.utility .firstTxtWrap .firstTxt {
    padding: 20px 25px
}

@media (max-width: 767px) {
    .utility .firstTxtWrap .firstTxt {
        padding: 5vw 0;
        width: calc(100% - 40px);
        line-height: 1.8
    }
}

.utility .firstTxt {
    background: #fff;
    color: #333;
    font-size: 14px;
    display: inline-block;
    padding: 15px 20px;
    display: none
}

@media (max-width: 767px) {
    .utility .firstTxt {
        padding: 3vw 0;
        width: 100%;
        text-align: center;
        font-size: 3.2vw !important
    }
}

.utility .boxClose {
    cursor: pointer
}