@font-face {
    font-family: 'ProductSans';
    font-weight: normal;
    font-style: normal;

    font-display: swap;
    src: local('ProductSans Regular'), local('ProductSans-Regular'), url(../fonts/ProductSans-Regular.woff2) format('woff2'), url(../fonts/ProductSans-Regular.woff) format('woff'), url(../fonts/ProductSans-Regular.ttf) format('truetype');
}

@font-face {
    font-family: 'AvantGardeBold';
    font-weight: bold;
    font-style: normal;

    font-display: swap;
    src: local('Avant Garde Bold'), local('Avant-Garde-Bold'), url(../fonts/Avant-Garde-Bold.woff2) format('woff2'), url(../fonts/Avant-Garde-Bold.ttf) format('truetype');
}

* {
    box-sizing: border-box;
}

body {
    font-family: 'ProductSans', system-ui, -apple-system, BlinkMacSystemFont, Segoe UI, 'Open Sans', 'Helvetica Neue', sans-serif;
    font-size: 14px;
    line-height: 1.78;

    color: #333;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

html {
    font-size: 100%;

    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
}

body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
dl,
dt,
dd {
    margin: 0;
    padding: 0;
}

a {
    cursor: pointer;
    text-decoration: none;

    color: #333;
}

a,
a:hover,
a:visited {
    outline: none;
}

img {
    max-width: 100%;

    transition: opacity ease .25s;
    vertical-align: middle;

    opacity: 1;
}

img[data-src] {
    opacity: 0;
}

button {
    border: none;
    background: none;
}

input:focus,
button:focus,
textarea {
    outline: none;
}

::-webkit-input-placeholder {
    color: #ccc;
}

::-moz-placeholder {
    color: #ccc;
}

:-ms-input-placeholder {
    color: #ccc;
}

article,
aside,
figure,
footer,
header,
main,
nav,
section {
    display: block;
}

li {
    list-style: none;
}

.coverlink {
    position: absolute;
    z-index: 3;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

.logo {
    position: relative;
    z-index: 1005;

    display: block;

    width: 108px;
    height: 56px;

    text-align: center;

    color: #fff;
    background: url(../Image/hiappo_logo.png) no-repeat left center;
    background-size: 108px 23px;
}

.ft-con .logo {
    z-index: 2;

    margin: 0 auto;
}

.opacityblack,
.opacitywhite {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;

    display: none;
}

.opacityblack {
    z-index: 1002;
    top: 0;

    transition: all ease .25s;

    background-color: rgba(0, 0, 0, .55);
}

.opacitywhite {
    z-index: 999;
    top: 48px;

    background-color: rgba(0, 0, 0, 0);
}

.search-icon {
    position: relative;

    display: block;

    width: 16px;
    height: 16px;
    padding-right: 5px;

    transform: rotate(-45deg);

    border: 2px solid #fb8240;
    border-radius: 100%;
}

.search-icon::after {
    position: absolute;
    top: 12px;
    left: 50%;

    display: block;

    width: 2px;
    height: 8px;

    content: '';

    background-color: #fb8240;
}

.search {
    position: absolute;
    z-index: 1007;
    top: 8px;
    /* left: 20px; */
    right: 73px;

    overflow: hidden;

    width: 0;
    height: 40px;

    transition: all ease .25s;

    border-radius: 20px;
    background-color: #fff;

    -ms-border-radius: 20px;
    -o-border-radius: 20px;
}

.search-form {
    display: flex;
    align-items: center;
    justify-content: center;

    width: 100%;
    min-width: 224px;
    height: 100%;
    padding-left: 16px;
}

.sea-text {
    font-size: 14px;

    flex: 1;

    height: 100%;

    border: none;
}

.sea-btn {
    position: absolute;
    right: 0;

    flex: 0 0 48px;

    width: 48px;
    height: 100%;
    padding-bottom: 4px;
    padding-left: 12px;
    cursor: pointer;
}

.search-pos {
    position: absolute;
    top: 50%;
    right: 20px;

    margin-top: -9px;
}

.search-pos .search-icon {
    border-color: #fb8240;
}

.search-pos .search-icon::after {
    background-color: #fb8240;
}

#searchmenu:checked~.opacitywhite {
    display: block;
}

#searchmenu:checked~.search {
    width: calc(100vw - 93px);

    border: 1px solid #eee;
}

.search-icon-wp {
    position: absolute;
    z-index: 1005;
    top: 19px;
    right: 70px;

    width: 24px;
    height: 20px;
}

.search-icon-wp .search-icon {
    border-color: #fff;
}

.search-icon-wp .search-icon::after {
    background-color: #fff;
}

#topmenu:checked~.opacityblack {
    display: block;
}

.topmenu-box {
    position: absolute;
    z-index: 1006;
    top: 0;
    right: 0;

    width: 56px;
    height: 56px;

    background-color: #fc7133;
    /* width: 20px;
    height: 16px; */
}

.menu-icon,
.menu-icon::before,
.menu-icon::after {
    width: 100%;
    height: 2px;

    border-radius: 2px;
    background-color: #fff;
}

.menu-icon {
    position: relative;
    z-index: 1000;
    top: 20px;
    left: 22px;

    display: block;

    width: 14px;
}

.menu-icon::before,
.menu-icon::after {
    position: absolute;
    top: 7px;
    right: 0;

    width: 20px;

    content: '';
    transition: all ease .25s;
}

.menu-icon::after {
    top: 14px;

    width: 10px;
}

#topmenu:checked~.topmenu-box .menu-icon {
    background: none;
}

#topmenu:checked~.topmenu-box .menu-icon::before {
    transform: rotate(45deg);
}

#topmenu:checked~.topmenu-box .menu-icon::after {
    width: 20px;

    transform: rotate(-45deg);
    transform-origin: 1px -2px;
}

.navfix {
    position: absolute;
    z-index: 1003;
    top: 0;
    bottom: 0;
    left: 0;

    width: 100%;
}

.menunav {
    overflow: hidden;

    max-height: 0;
    padding-right: 20px;
    padding-left: 20px;

    text-align: left;

    border-top: 56px solid #fb8240;
    background-color: #fff;
}

#topmenu:checked~.navfix .menunav {
    max-height: 1200px;
    padding-top: 24px;
    padding-bottom: 40px;

    transition: all 600ms cubic-bezier(.165, .84, .44, 1);
}

.pcads {
    display: none;
}

.common-tl,
.reviewcon h3,
.privacy-tl {
    font-family: 'AvantGardeBold';
}

.wrapper {
    position: relative;

    padding-right: 20px;
    padding-left: 20px;
}

input[type='checkbox'] {
    display: none;
}

.header-con {
    background-color: #fb8240;
}

.pcnav {
    display: none;
}

.common-tl {
    font-size: 20px;

    display: flex;
    align-items: center;

    margin: 20px 0;
}

.smallmargin {
    margin-top: 12px;
    margin-bottom: 12px;
}

.common-tl-icon {
    display: block;

    width: 32px;
    height: 32px;
    margin-right: 12px;

    background-image: url(../Image/title_bg.png);
    background-size: 32px 96px;
}

.icontwo {
    background-position: 0 -32px;
}

.iconthree {
    background-position: 0 -64px;
}

.ringtone-ls {
    margin-top: 20px;
}

.ringtone-item {
    margin-bottom: 16px;
}

.ringtone-con {
    position: relative;

    display: flex;
    align-items: center;
}

.ringtone-info {
    overflow: hidden;
    flex: 1;

    padding-left: 12px;
}

.ringtone-tl {
    font-size: 16px;
    font-weight: normal;
    line-height: 1.1;

    display: flex;
    align-items: center;
    justify-content: space-between;
}

.ringtone-tl a {
    overflow: hidden;

    white-space: nowrap;
    text-overflow: ellipsis;
}

.ringtone-cate {
    color: #aaa;
    font-size: 12px;
}

.ringtone-time {
    font-size: 14px;

    color: #ccc;
}

.icon-start {
    position: relative;

    flex: 0 0 32px;

    width: 32px;
    height: 32px;

    border: 2px solid #fb8240;
    border-radius: 100%;
}

.icon-start::before {
    position: absolute;
    top: 5px;
    left: 11px;

    width: 0;
    height: 0;

    content: '';

    border: 8px solid #fb8240;
    border-color: transparent transparent transparent #fb8240;
    border-radius: 4px;
}

.ringtone-sub {
    display: flex;
    align-items: center;

    height: 20px;
}

.icon-hot {
    width: 10px;
    height: 12px;
    margin-right: 6px;
    /* margin-bottom: 2px; */
}

.new-icon {
    font-size: 20px;
    line-height: 28px;

    display: block;

    width: 60px;
    height: 28px;
    margin-right: -24px;

    transform: scale(.5);
    transform-origin: 0 center;
    text-align: center;

    color: #fff;
    border-radius: 6px;
    background-color: #333;
}

.ringtone-more {
    font-size: 15px;
    line-height: 40px;

    display: block;

    height: 40px;
    margin: 20px 0 24px;

    text-align: center;

    color: #666;
    border: 2px solid #eee;
    border-radius: 20px;
}

.category-rt {
    margin-bottom: 16px;
}

.category-ls {
    display: flex;
    flex-wrap: wrap;

    margin-left: -8px;
}

.category-item {
    width: 50%;
    margin-bottom: 8px;
    padding-left: 8px;
}

.category-con {
    font-size: 15px;
    line-height: 40px;

    display: flex;
    justify-content: space-between;

    height: 40px;
    padding: 0 16px;

    border-radius: 20px;
    background-color: #fafafa;
}

.category-sum {
    font-size: 12px;

    color: #aaa;
}

.footer {
    font-size: 15px;
    line-height: 1.53;

    margin-top: 24px;
    padding: 20px 0 40px;

    text-align: center;

    color: rgba(255, 255, 255, .5);
    background-color: #171b21;
}

.ft-tl {
    margin-top: 4px;
    margin-bottom: 10px;

    color: #fb8240;
}

.audio-page {
    font-size: 18px;
    ;

    display: flex;
    align-items: center;
    justify-content: center;

    margin: 24px 0;

    text-align: center;
}

.page-right-wp {
    width: 48px;
    height: 48px;
    margin: 0 20px;
}

.page-right,
.page-left {
    line-height: 48px;

    display: flex;
    align-items: center;
    justify-content: center;

    width: 48px;
    height: 48px;

    border-radius: 12px;
    background-color: #fb8240;
}

.page-right .icon-right,
.page-left .icon-left {
    width: 24px;
    height: 24px;

    transition: all ease .25s;

    fill: #fff;
}

.review-tl {
    font-size: 20px;

    margin: 12px 0;

    text-align: center;
}

.audio-ls {
    display: flex;
}

.audio-item {
    flex: 1;

    text-align: center;
}

.audio-text {
    display: block;
    white-space: nowrap;
    font-size: 12px;
    color: #aaa;
}

.audio-info {
    font-size: 13px;
}

.audio-cate-link {
    color: #fb8240;
}

.audio-down {
    display: flex;

    margin-top: 20px;
    margin-bottom: 32px;
    margin-left: -8px;
}

.audio-down-item {
    flex: 1;

    padding-left: 8px;
}

.audio-sound-wrap {
    margin-bottom: 24px;
}

.audio-down-link {
    display: flex;
    align-items: center;
    justify-content: center;

    height: 48px;
    font-size: 12px;
    color: #fff;
    border-radius: 24px;
    background-color: #333;
}

.icon-right {
    width: 15px;
    height: 15px;
}

.icon-down {
    flex: 0 0 20px;

    width: 20px;
    height: 20px;
    margin-right: 4px;
}

.audio-down-link .icon-down {
    fill: #fff;
}

.audio-able .icon-down {
    fill: #666;
}

.audio-help {
    /* line-height: 1.2; */

    line-height: 20px;
    position: relative;

    display: flex;
    align-items: center;

    margin-bottom: 32px;
    padding-right: 100px;

    white-space: nowrap;
}

.audio-able {
    position: absolute;
    right: 0;

    display: flex;
    align-items: center;
    justify-content: flex-end;

    width: 100px;
}

.icon-down-bg {
    position: relative;

    display: flex;
    align-items: center;
    justify-content: center;

    width: 40px;
    height: 40px;
    margin-left: 6px;

    border-radius: 20px;
    background-color: #eee;
}

.icon-down-bg .icon-down {
    margin-right: 0;
}

.audio-report {
    line-height: 40px;

    display: flex;
    align-items: center;

    width: 100%;
    height: 40px;
    padding-right: 8px;
    padding-left: 12px;
    /* margin-top: 32px; */

    cursor: pointer;

    color: #999;
    border: 1px solid #eee;
    border-radius: 8px;
}

.audio-report-info {
    flex: 1;
}

.audio-data {
    display: flex;
    align-items: center;

    margin-top: 12px;
}

.audio-times {
    font-size: 15px;

    color: #999;
}

.gray-line {
    position: relative;

    flex: 1;

    height: 5px;
    margin: 0 12px;

    border-radius: 2px;
    background-color: #efefef;
}

.active-line {
    position: absolute;
    left: 0;
    /* width: 10%; */

    height: 5px;

    transition: width ease .25s;

    border-radius: 2px;
    background-color: #fb8240;
}

.audio-action {
    display: flex;
    align-items: center;
    justify-content: center;

    margin: 32px 0;
}

.audio-status {
    position: relative;

    width: 64px;
    height: 64px;
    margin: 0 40px;

    cursor: pointer;

    border-radius: 100%;
    background-color: #fb8240;
    box-shadow: 0 0 0 7px rgba(251, 130, 61, .2);
}

.audio-status::after {
    position: absolute;
    top: 22px;
    left: 26px;

    width: 0;
    height: 0;

    content: '';

    border: 10px solid #fff;
    border-color: transparent transparent transparent #fff;
    border-left-width: 18px;
    border-radius: 3px;
}

.audio-pause::after {
    left: 25px;

    width: 5px;
    height: 22px;

    border: none;
    background-color: #fff;
    box-shadow: 10px 0 0 0 #fff;
}

.prev-audio,
.next-audio {
    position: relative;

    display: block;

    width: 0;
    height: 0;

    border: 10px solid #fb8240;
    border-radius: 3px;
}

.prev-audio {
    border-color: transparent #fb8240 transparent transparent;
    border-right-width: 16px;
}

.next-audio {
    border-color: transparent transparent transparent #fb8240;
    border-left-width: 16px;
}

.prev-audio::after,
.next-audio::after {
    position: absolute;
    top: -8px;

    width: 3px;
    height: 16px;

    content: '';

    border-radius: 3px;
    background-color: #fb8240;
}

.prev-audio::after {
    left: -3px;
}

.next-audio::after {
    right: -3px;
}

#facing {
    position: fixed;
    z-index: 1008;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;

    transition: all ease .25s;
    pointer-events: none;

    background-color: rgba(0, 0, 0, .55);
}

.modal {
    position: fixed;
    z-index: 1009;
    top: 50%;
    left: 50%;

    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: center;

    width: 300px;
    height: 200px;
    margin-top: -100px;
    margin-left: -150px;
    padding: 0 32px;

    transition: all ease .25s;
    transform: translateY(-100px);
    pointer-events: none;

    opacity: 0;
    border-radius: 4px;
    background-color: #fff;
}

.modal-tl {
    font-size: 16px;
    line-height: 26px;

    margin: 0;

    text-align: center;
}

.modal-btn {
    line-height: 48px;

    width: 120px;
    margin-top: 16px;

    cursor: pointer;
    text-align: center;

    color: #fff;
    border-radius: 24px;
    background-color: #fb8240;
}

.usetips {
    font-size: 13px;
    ;

    position: fixed;
    z-index: 9;
    right: 0;
    bottom: 0;
    left: 0;

    width: 100%;
    padding: 10px;

    transition: opacity ease .25s;
    pointer-events: none;

    opacity: 0;
    color: #fff;
    background-color: rgba(115, 115, 115, .9);
}

.usetips-link {
    font-size: 13px;
    ;

    text-decoration: underline;

    color: #fff;
}

.usetips-ls {
    margin-top: 10px;
}

.usetips-item {
    font-size: 13px;
    ;
    line-height: 28px;

    display: inline-block;

    width: 100px;
    height: 28px;
    margin-right: 10px;

    cursor: pointer;
    text-align: center;

    color: #fff;
    border: 1px solid rgba(255, 255, 255, .5);
    border-radius: 4px;
}

.category-hot {
    background-color: rgba(251, 130, 61, .08);
}

.category-hot .category-link {
    color: #fb8240;
    white-space: nowrap;

}

span.usetips-item {
    color: #333;
    border-color: #fff;
    ;
    background-color: #fff;
}

.reviewcon nav,
.reviewcon h3,
.reviewcon p,
.reviewcon img {
    margin: 14px 0;
}

.how-link {
    line-height: 1.4;

    display: block;

    padding: 6px 0;

    text-decoration: underline;
    ;

    color: #fb8240;
}

.reviewcon img {
    width: 100%;
}

.repicfix {
    width: 100%;
    height: 200px;
    margin-bottom: 16px;

    -o-object-fit: cover;
    object-fit: cover;
}

.searchpage {
    margin: 0 8px;
    min-height: 100vh;
    min-height: calc(100vh - 180px);
    min-height: -webkit-calc(100vh - 180px);
}
.privacypage{
    min-height: calc(100vh - 180px);
}
.about-us h2{
    margin-top: 16px;
    margin-bottom: 10px;
}
.about-us h3{
    margin-bottom: 10px;
}
.about-us ul{
    margin-bottom: 14px;
    padding-left: 40px;
}
.about-us li{
    line-height: 24px;
    margin-bottom: 8px;
    list-style: disc;
}
.about-us p{
    line-height: 24px;
    margin-bottom: 14px;
}
.about-us h4
{
    line-height: 24px;

    margin: 14px 0;
}

.about-us h6,
.about-us h4
{
    font-size: 14px;
    font-weight: 700;
    line-height: 25px;

    margin: 14px 0;
}

.row-item {
    border: 1px solid rgba(255, 255, 255, .1);
    position: relative;
    display: block;
    margin: 20px 0;
    box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.12), 0px 1px 1px rgba(0, 0, 0, 0.14), 0px 2px 1px -1px rgba(0, 0, 0, 0.20);
    border-radius: 8px;
    padding: 12px 16px;
}

.row-tl {
    color: #fb8240;
    margin-top: 4px;
    font-size: 16px;
}

.row-info {
    color: #999;
}

.row-logo {
    width: 16px;
    height: 16px;
    margin-right: 5px;
    display: inline-block;
    vertical-align: bottom;
}

.row-curlink {
    font-size: 12px;
    color: #3C4043;
    line-height: 16px;
    position: relative;
    /* padding-left: 30px; */
    display: flex;
    align-items: center;
    /*margin-bottom: 12px;*/
}

.row-curlink .icon-start {
    width: 20px;
    height: 20px;
    flex: 0 0 20px;
    margin-right: 6px;
}

.row-curlink .icon-start::before {
    border-width: 6px;
    top: 2px;
    left: 6px;
}

.cate-turnpage {
    margin: 24px 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

.cate-turnpage-item {
    border: 1px solid #eee;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    -ms-border-radius: 3px;
    -o-border-radius: 3px;
    width: 40px;
    height: 40px;
    margin: 0 4px;
    color: #fb8240;
    display: flex;
    align-items: center;
    justify-content: center;
}

.other-turnpage {
    border-width: 0;
}

.active-turnpage {
    color: #333;
}

.cate-icon-left,
.cate-icon-right {
    width: 14px;
    height: 14px;
    fill: #fb8240;
}

.cate-page-disable .cate-icon-left,
.cate-page-disable .cate-icon-right {
    fill: #eee;
}

.noresult-tl {
    margin-top: 20px;
    margin-bottom: 18px;
}

.noresult-ls {
    margin: 15px 0;
}

.noresult-item {
    line-height: 20px;
    position: relative;
    padding-left: 3px;
}

.noresult-item::before {
    content: '';
    width: 4px;
    height: 4px;
    background-color: #333;
    border-radius: 4px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 10px;
}

.privacy-tl {
    font-size: 20px;
    margin: 14px 0;
}

table {
    border-left: 1px solid #eee;
    border-top: 1px solid #eee;
}

table tr td,
table tr th {
    border-right: 1px solid #eee;
    border-bottom: 1px solid #eee;
    padding: 10px;
    line-height: 1.4;
}

@media screen and (min-width: 414px) {

    .audio-down-link,
    .audio-text {
        font-size: 14px;
    }

    .icon-down {
        margin-right: 8px;
    }

    .audio-info {
        font-size: 15px;
    }
}

@media screen and (min-width: 768px) {
    .wrapper {
        max-width: 768px;
        margin: 0 auto;
    }

    .ringtone-ls {
        display: flex;
        flex-wrap: wrap;
    }

    .ringtone-item {
        flex: 0 0 50%;

        width: 50%;
    }

    .ringtone-time,
    .category-sum,
    .topmenu-box,
    .navfix {
        display: none;
    }

    .ringtone-more {
        margin-top: 4px;

        cursor: pointer;
    }

    .search {
        right: 20px;

        width: 300px;
    }

    .comnav {
        display: flex;
        align-items: center;
        justify-content: space-between;

        padding-right: 348px;
    }

    .pcnav {
        display: flex;
    }

    .pcnav-link {
        color: #fff;
    }

    .pcnav-link {
        font-size: 16px;
        line-height: 56px;

        display: block;

        padding-right: 20px;
        padding-left: 20px;
    }

    .menu-active-link {
        background-color: #fc7133;
    }
}

@media screen and (min-width: 1114px) {
    .wrapper {
        max-width: 1114px;
    }

    .pagecontent {
        display: flex;
    }

    .pageleft {
        flex: 0 0 728px;

        width: 728px;
    }

    .pageright {
        flex: 1;

        padding-top: 35px;
        padding-left: 46px;
    }

    /* .reviewpage .pageright{
        margin-top: -20px;
    } */
    #userConsent {
        padding-right: 250px;
    }

    .usetips-ls {
        position: absolute;
        top: 50%;
        right: 20px;

        margin-top: -17px;
    }

    .usetips-item {
        line-height: 34px;
        ;

        height: 34px;
    }

    .usetips-item,
    .usetips-link {
        font-size: 14px;
    }

    .usetips {
        padding: 20px;
    }

    .logo {
        width: 148px;

        background-size: 148px 32px;
    }

    .footer {
        text-align: left;
    }

    .ft-con .logo {
        /* margin-left: 0; */
        margin: 10px 0;
    }

    .ft-con {
        max-width: 768px;
    }

    .pcnav-link:hover {
        background-color: #fc7133;
    }

    .ringtone-con:hover .ringtone-tl a,
    .category-con:hover .category-link,
    .active-link {
        text-decoration: underline;

        color: #fb8240;
    }

    .icon-down-bg:hover .icon-down {
        fill: #333;
    }
}